❯ Проблема простого UI-интерфейса для баз данных

В ходе разработки сайта, приложения или программы иногда хочется поработать с данными в базе визуально, через UI.

Для этого есть много профессиональных инструментов. Как бесплатные, вроде MySQL Workbench, pgAdmin, DBeaver, Beekeeper Studio или культовой phpMyAdmin, так и платные, где еще больше разных наворотов.

Но что, если нужно что-то максимально простое и удобное?

Такие решения тоже есть. Например, Prisma Studio и Drizzle Studio от разработчиков PrismaORM и DrizzleORM. Однако с точки зрения удобства и функций им еще есть куда расти. Да и это всё-таки больше дополнения к ORM, чем самостоятельные инструменты.

Однако, всё-таки есть инструмент, который неплохо решает описанную проблему — и это NocoDB, или просто «Ноко».

Просмотр данных в виде таблицы в NocoDB
Просмотр данных в виде таблицы в NocoDB

❯ Чем интересен NocoDB

NocoDB не особо известен в среде разработчиков просто потому, что у инструмента изначально другая целевая аудитория и другое позиционирование.

Ноко создавался как open-source альтернатива популярному платному инструменту Airtable. Который в свою очередь создавался как альтернатива Excel. И цель всех этих инструментов — решать бизнес-задачи руками пользователей-непрограммистов.

А именно — создавать наглядные базы данных клиентов, лидов, продуктов, заказов, сотрудников и т. д. Вести управленческий, финансовый, кадровый, товарный, складской учёт и многое остальное, что необходимо бизнесу.

Таблица со списком товаров
Таблица со списком товаров

И конечно в этой основной своей роли NocoDB тоже интересен. Но для тех, кто занимается разработкой и работает с базами данных, он будет в первую очередь интересен своей важной побочной функцией — возможностью подключать любые внешние базы PostgreSQL или MySQL и работать с ними.

При этом Ноко предоставляет исходный код, а значит его можно ставить на свой собственный сервер и использовать без ограничений на количество записей, операций, запросов к API и т. д.

В результате этот инструмент решает сразу несколько задач разных типов пользователей:

  • Непрограммисты могут использовать его просто как альтернативу Airtable, гугл-таблицам или специализированным SaaS-системам для личных нужд или бизнеса. Это особенно актуально сейчас, потому что всё больше сервисов окончательно закрывают доступ к своим платформам для пользователей из России. Как раз недавно к их числу присоединился и Airtable.

  • А программисты могут использовать его как UI-интерфейс для наглядной работы с данными в базах.

  • Также любые группы пользователей могут использовать Ноко в качестве CMS-системы для изменения данных сайта/приложения. Конечно, это спорный способ применения, которым нужно пользоваться аккуратно, но иногда это вполне рабочий вариант.

Товары в виде карточек
Товары в виде карточек

И подобный инструмент становится особенно полезным сейчас, когда ИИ сделал любительскую разработку сайтов, программ и приложений доступной широким массам. Потому что выросла потребность в максимально простых и удобных инструментах для решения технических задач.

Поэтому предлагаю сегодня познакомиться с тем, какие возможности есть в NocoDB, как его установить для работы и как им правильно пользоваться.

❯ Отличия разных версий NocoDB

NocoDB идёт в нескольких версиях, которые существенно отличаются друг от друга.

  • Бесплатная версия для установки на собственном сервере — без ограничений на число записей, запросов и т. д. Отсутствуют разные второстепенные функции для бизнес-нужд.

  • Платная Enterprise-версия для установки на собственном сервере — есть дополнительные бизнес-функции.

  • Бесплатный тариф облачной версии — на практике бесполезный, но подходит, чтобы быстро ознакомиться с возможностями программы.

  • Платные тарифы облачной версии — содержат много разных бизнес-функций: дашборды, ИИ-ассистент, расширения, синхронизация данных. Но есть существенные ограничения по числу записей, запросов, пользователей и т. д. Хотя вроде бы выходит дешевле, чем пользоваться Airtable.

Сегодня нас интересует только бесплатная версия NocoDB для хостинга на собственном сервере. Она доступна на GitHub.

Отметим, что в бесплатной версии в интерфейсе повсюду встречаются неактивные кнопки и элементы, которые по сути просто рекламируют Enterprise-версию. В нашем обзоре мы будем их игнорировать.

При этом, если вам хочется просто посмотреть на Ноко, но пока не тратить время на его установку, то можно попробовать облачную версию на бесплатном тарифе Free. Хотя для полноценной работы это не подходит.

Ещё облачная версия может быть интересна для первого знакомства, потому что там доступно множество готовых шаблонов, которые дают базовое понимание, как в целом можно использовать NocoDB в качестве базы данных для бизнеса.

❯ Варианты сборки NocoDB

Минимально рабочая версия NocoDB это только само приложение. Тогда по умолчанию в качестве основной базы данных будет использоваться лёгкая файловая база SQLite.

При этом для серьёзного продакшн-использования вы скорее всего захотите расширить сборку дополнительными инструментами, например:

  • База PostgreSQL вместо SQLite.

  • База Redis для кэширования.

  • S3-хранилище для хранения загружаемых файлов (изображений и т. д.).

  • Почтовый сервер для отправки писем.

  • Litestream для бэкапов, если вы используете SQLite.

  • Sentry для логгинга и мониторинга.

  • Что-нибудь для автоматического обновления контейнеров по мере выхода новых версий.

Но для того, чтобы начать работать с NocoDB, ничего из перечисленного не обязательно.

Поэтому в этой статье мы будем рассматривать только самую простую сборку: с базой SQLite и ревер-прокси для подключения домена и TLS-сертификата.

Напомним, что для работы с ценными данными крайне важно всегда иметь настроенные бэкапы, но мы не будем на этом останавливаться.

❯ Подготовка сервера

Если вы хотите поставить NocoDB на облачном сервере (VPS) и сделать его доступным по нужному адресу, то потребуется подготовка: приобрести VPS, домен, прописать DNS, добавить SSH-ключи, открыть нужные порты при необходимости.

Как это всё сделать на примере облачного провайдера Timeweb Cloud, я разбирал в одной из прошлых статей.

Если на сервере будет только NocoDB с базой SQLite, то для запуска должно хватить минимальной конфигурации 1 CPU, 1 RAM, 15 GB NVMe. Но надо иметь в виду, что это впритык, и для комфортной работы навырост нужен будет сервер помощнее.

Также напомню, что при установке на VPS может возникнуть ошибка, связанная с ограничением скачиваний образов из докер-реестра. Например, с таким текстом: «Error response from daemon: error from registry: You have reached your unauthenticated pull rate limit. https://www.docker.com/increase-rate-limit».

Чтобы это обойти, достаточно создать аккаунт на сайте https://hub.docker.com/ и затем с этим аккаунтом авторизоваться на сервере через команду docker login. Предварительно Docker уже должен быть установлен на сервере.

❯ Установка через скрипт «Auto-Upstall» не работает

Хотя self-hosted версия NocoDB по прежнему поддерживается и получает обновления, но документация по её установке сильно устарела.

Например, в доках первую очередь предлагается установка через скрипт «Auto-Upstall». Хотя процесс установки через этот скрипт пройдет до конца и будет выглядеть успешным, но NocoDB не запустится.

Дело в том, что этот скрипт пытается установить не минимальную сборку NocoDB, а расширенную с дополнительными инструментами, как мы перечисляли выше. И часть указанных образов в сборке сильно устарели и больше не совместимы с текущей версией Docker. Более того, некоторые проекты в сборке (MiniO и Watchtower) вообще больше не поддерживаются.

В общем, на момент написании статьи, этот скрипт не работает и нуждается в актуализации.

❯ Рабочие способы установки NocoDB

Так что давайте разберемся, как же нам лучше всего установить NocoDB.

Простой запуск базового Docker-образа

Можно просто запустить NocoDB в докер-контейнере. Этот способ пойдет для локальной работы или для временного тестового запуска на сервере, если нет домена.

Рассмотрим на примере установки на сервер с Ubuntu.

Если нужно, сначала ставим Docker Engine быстрым способом.

curl -fsSL https://get.docker.com -o get-docker.sh
sudo sh ./get-docker.sh

Авторизуемся в Docker, чтобы не было проблем при скачивании образов.

docker login

В процессе авторизации нужно будет выполнить предложенные шаги, например перейти по ссылке и ввести код подтверждения.

Далее создаем папку приложения, переходим в неё и создаем ещё папку для постоянного хранения данных.

mkdir -p ~/apps/nocodb
cd ~/apps/nocodb
mkdir -p data

И наконец запускаем контейнер с NocoDB:

docker run -d --name nocodb \
  -v "$(pwd)"/data:/usr/app/data \
  -p 8080:8080 \
  --restart unless-stopped \
  nocodb/nocodb:latest

Эта команда скачает актуальный докер-образ, смонтирует том/volume для хранения данных, запустит контейнер и выведет его на порт 8080.

После этого рабочий NocoDB будет доступен, если перейти в браузере по IP-адресу вашего сервера с портом 8080, например http://123.123.123.123:8080/ При этом будет предупреждение, что соединение не защищено.

Наш готовый скрипт установки NocoDB + Caddy

Но при установке на облачный сервер (VPS) конечно хочется, чтобы NocoDB всё-таки открывался по нормальному адресу и через защищённый протокол HTTPS.

Для этого NocoDB нужно установить вместе с реверс-прокси, например Caddy. Для совместного их запуска можно использовать Docker Compose.

Для тех, кто не хочет в этом разбираться, мы подготовили скрипт для простой пошаговой установки сборки NocoDB с Caddy.

Запустить скрипт на английском:

bash <(curl -fsSL https://gist.githubusercontent.com/nickneustroev/3da5fcc250555f755bfdef93c72e766b/raw)

Запустить на русском:

bash <(curl -fsSL https://gist.githubusercontent.com/nickneustroev/3da5fcc250555f755bfdef93c72e766b/raw) --lang ru

Вот что делает скрипт:

  1. Установит docker и docker-compose, если их нет.

  2. Попросит ввести адрес для NocoDB. Укажите ваш заранее подготовленный домен/поддомен, например: nocodb.ivanivanov.ru.

  3. Проверит, что DNS для домена указывают на текущий сервер.

  4. Напомнит, что желательно авторизоваться на сервере в docker, чтобы не было проблем с загрузкой образов из реестра.

  5. Через Docker Compose установит сам NocoDB с базой SQLite, а также Caddy для домена и TLS-сертификата.

После успешной установки можно открыть NocoDB по нужному адресу (порт указывать не нужно). Установленный NocoDB с базой SQLite занимает на сервере около 500 мегабайт оперативной памяти.

Скрипт сделан с помощью ИИ, но был внимательно протестирован. Если есть пожелания, как его можно исправить или улучшить, пишите в комментариях или в личку.

Установка с помощью Coolify

Однако есть специальный инструмент для удобного управления приложениями на основе docker на личном облачном сервере — это Coolify, про который мы уже выпустили серию статей.

Установить NocoDB через Coolify довольно просто:

  1. Заходим в проект и нажимаем «Add resource».

  2. В списке Services находим и выбираем NocoDB.

  3. Указываем сервер, если необходимо.

  4. Ресурс будет создан и мы попадаем на страницу его настроек. Но сам сервис на данный момент еще не запущен.

  5. Можно поменять «Service Name» — имя ресурса.

  6. По умолчанию для каждого сервиса (Services) в Coolify создается своя собственная внутренняя сеть. Но иногда вы захотите подключить сервис к уже существующей в Coolify сети. Если это потребуется, то тут можно включить галочку «Connect To Predefined Network».

  7. Чтобы указать адрес приложения, в карточке контейнера NocoDB нажимаем иконку редактирования возле домена. И там в поле Domains указываем нужный адрес, например «https://nocodb.ivanivanov.ru:8080». Обратите внимание, что в этом поле в конце должен быть прописан порт 8080 — но сайт потом будет открываться по обычному нормальному адресу без порта.

  8. При необходимости, можно переключиться на вкладку Environment Variables, чтобы дописать переменные окружения для каких-то интеграций или настроек.

  9. Когда все настройки готовы, нажимаем «Deploy» в верхнем правому углу, чтобы запустить сервис.

Установка NocoDB через Coolify
Установка NocoDB через Coolify

❯ Сразу после установки

Сразу после установки лучше подождать полминуты, чтобы приложение окончательно запустилось, и TLS-сертификаты заработали. После этого можно переходить по ссылке.

Сначала у вас открывается окно регистрации администратора. Вам нужно указать e-mail и придумать пароль.

Далее вам предложат пройти быстрый опрос о том, кем вы работаете, как вы планируете использовать Noco и т. д. Но его можно пропустить, нажав на малозаметную кнопку Skip снизу.

После этого вы наконец попадаете в NocoDB.

❯ Стартовый экран рабочего пространства (Workspace)

Работа в Ноко поделена на рабочие пространства (Workspaces). По умолчанию создаётся пространство «Default Workspace» и при первом входе открывается его стартовая страница.

Стартовый экран рабочего пространства
Стартовый экран рабочего пространства

Вверху есть вкладки для управления пространством:

  • Bases — показывает список созданных баз.

  • Members — список пользователей.

  • Integrations — внешние интеграции. В бесплатной версии доступны только базы MySQL и PostgreSQL.

  • Settings — настройки (название и иконка).

Вкладки Teams и Audits это заблокированные Enterprise-функции, о чём говорит специальная иконка возле них. Мы не будем касаться их в нашем обзоре.

По умолчанию при входе открыта вкладка Bases и мы видим, что уже сразу создана база под названием «Getting Started».

❯ Стартовый экран базы

При клике на название базы открывается её стартовый экран со списком возможных действий:

  • Create New Table — создать новую таблицу.

  • Import Data — импортировать данные.

  • Create New Document — создать новый документ.

  • Connect External Data — подключить внешнюю базу данных.

Стартовый экран базы со списком возможных действий с ней
Стартовый экран базы со списком возможных действий с ней

Только стоит сразу пояснить, что в NocoDB называется базой. В терминах Ноко внутренняя база (Base) это изолированное рабочее пространство с несколькими таблицами. Т. е. технически может быть так, что у вас будет одна база данных (например, SQLite) и на основе неё множество внутренних баз. И ещё много подключений к внешним базам, но об это дальше.

❯ Элементы навигации

Когда вы находитесь внутри базы, то слева у вас будут элементы навигации по ней.

Слева у самого края мы видим боковую мини-панель с тремя пунктами, из которых доступно два:

  • Data (Данные) — собственно, рабочая зона. При клике на Data в боковой мини-панели как раз открывается страница возможных действий с этой базой.

  • Settings (Настройки).

Таблица с элементами навигации слева
Таблица с элементами навигации слева

В этой же панели в самом верху в углу есть иконка «Home», чтобы вернуться на уровень рабочего пространства.

Также слева мы видим сайдбар, который содержит:

  • Название текущей внутренней базы (например, «Getting Started»). По клику можно увидеть разные быстрые действия с этой базой (переименовать, скопировать и т. д.).

  • Кнопка «Create new» для создания новой таблицы в базе

  • Список всех таблиц в базе.

❯ Добавление и редактирование полей и записей

Чтобы начать работу с данными, выберите нужную таблицу в сайдбаре или создайте новую.

По умолчанию данные отображаются в виде табличной сетки (Grid). Чтобы добавить новое поле (столбец), можно нажать на «плюс» справа от заголовков столбцов.

Добавление нового поля (столбца) в таблицу
Добавление нового поля (столбца) в таблицу

Среди типов полей доступны как самые базовые, например строка текста, число, дата, валюта, чекбокс, выпадающий список, e-mail и другие. Так и более продвинутые, например формула, рейтинга, QR-код, баркод, координаты, кнопка, JSON и остальные.

С добавлением новых записей тоже всё просто. Первый способ — нажать на плюс в нижней части списка, чтобы создать пустую строку, а затем прямо в ячейках вписать нужные значения.

Второй способ — нажать «New Record» в нижней части страницы, чтобы открыть форму для создания новой записи.

Аналогично и с редактированием. Можно изменить данные в ячейках прямо в таблице. А можно нажать на кнопку детального просмотра у конкретной записи в строке, чтобы открыть аналогичное окно детального просмотра с формой редактирования.

Редактирование записи
Редактирование записи

Тут можно не только изменить запись, но и оставлять комментарии и просматривать историю изменений.

❯ Настройки выборки данных

Над таблицей имеется тулбар для управления выборкой данных:

  • Fields (Поля) — чтобы включать/выключать видимость конкретных полей таблицы и упорядочивать их.

  • Filter (Фильтр) — чтобы строить сложные фильтры.

  • Group (Группы) — для группировки данных в таблице.

  • Sort (Сортировка) — для сортировки данных.

  • Иконка со стрелками — для настройки размеров строк таблицы.

  • Кнопка дополнительных действий — где в том числе есть кнопки импорта и экспорта данных.

Настройка фильтрации записей
Настройка фильтрации записей

❯ Разные представления данных (View)

Большое удобство работы с NocoDB заключается в том, что не нужно каждый раз настраивать фильтры, сортировки и другие параметры отображения. Потому что для каждой таблицы можно добавить любое число разных предоставлений (View), и у каждого из этих предоставлений данные будут выводиться по разному.

В каждой таблице должно быть хотя бы одно представление, оно создаётся по умолчанию и называется аналогично самой таблице (см. пример на скрине выше).

При этом таблица — это не единственный способ вывода данных из базы. Всего есть следующие типы представлений:

  • Сетка (Grid) — уже рассмотренное отображение данных в виде простой таблицы, как в гугл-таблицах

  • Форма (Form) — позволяет настроить форму и далее открыть ее для общего доступа, чтобы собирать данные.

  • Галерея (Gallery) — просмотр записей в виде карточек

  • Канбан (Kanban) — просмотр записей в виде канбан-доски (на основе выбранного поля с вариантами значений)

  • Календарь (Calendar) — календарь по дням, неделям, месяц или годам.

  • Карта (Map) — карта с маркерами

Вывод карточек в виде канбан-доски
Вывод карточек в виде канбан-доски
Редактирование формы
Редактирование формы

❯ Публичный доступ к базе или представлению

Отдельный плюс, что каждое представление можно открыть для общего доступа. И тогда любой человек сможет открыть их по ссылке, и даже использовать фильтрацию и сортировку.

Таким образом можно легко решать разные задачи, например:

  • Сделать каталог товаров.

  • Создать сайт-директорию.

  • Показывать прогресс разработки на канбан-доске.

  • Выводить расписание мероприятий.

  • Показывать в календаре свободное время для записи.

  • Собирать заявки и обратную связь.

  • Проводить опросы.

  • И многое другое

Каталог товаров в расшаренном виде
Каталог товаров в расшаренном виде

Для включения публичного доступа в верхнем правом углу страницы есть кнопка Share. Там есть два варианта:

  • Enable Public Viewing — поделиться только данным представлением (view).

  • Share Base — открыть базу целиком, т. е. будут доступны все представления базы.

После включения общего доступа появятся настройки шеринга, в том числе:

  • Restrict access with password — сделать доступ к странице только паролю.

  • Allow Download — разрешить скачивание данных.

  • Language — выбрать язык интерфейса.

  • Survey Mode — режим формы, при котором каждое поле показывается постепенно по отдельности.

  • Default Theme — тема по умолчанию (темная или светлая).

  • Enable Pre-fill — заполнять поля формы значениями по умолчанию.

Конкретный набор настроек зависит от типа представления.

Ещё можно скопировать код для вставки представления через iframe и таким образом интегрировать представление на ваш сайт.

❯ Детали базы (Details)

В навбаре в самом верху страницы по центру есть переключатель, где можно перейти с Data (Данные) на Details (Детали).

В Деталях есть следующие вкладки:

  • Fileds (поля) — для просмотра и детальной настройки полей таблицы.

  • Relations (отношения) — для просмотра ERD-диаграммы, которая наглядно показывает связи между текущей таблицей и остальными.

  • API Snippets — примеры кода для подключения к базе через API. Т. е. NocoDB может сразу играть роль бэкенда, позволяя работать с данными через API.

  • Webhooks — список настроенных вебхуков этой базы. Вебхуки позволяют отправлять определенные запросы со стороны NocoDB в случае конкретных событий (триггеров) в базе — например, создание записей в конкретной таблице.

Связи между таблицами
Связи между таблицами

❯ Подключение дополнительных внешних баз

Кроме основной базы, к NocoDB можно подключать отдельные уже созданные внешние реляционные базы PostgreSQL или MySQL.

Мы уже рассказывали, как создавать базы данных на своем облачном сервере с помощью Coolify.

Рассмотрим подключение по шагам:

  1. Есть несколько способов перейти к созданию нового подключения. Можно на странице действий с базой (кнопка Data) нажать «Connect External Data». (Подключить внешний источник). Или можно перейти в Settings и там в «Manage Data Sources» кликнуть «New Data Source». В любом случае откроется форма «Add Data Source» (добавление источника)

  2. При желании прописываем название подключения в поле «Data Source Name».

  3. В поле Connection выбираем «New Connection». Появляется модальное окно создания нового подключения.

  4. В новом окне выбираем тип БД — PostgreSQL или MySQL

  5. Прописываем понятное Connection name.

  6. Затем нужно ввести все данные для подключения. Проще всего не вводить их по отдельности, а кликнуть «Use Connection URL» и вписать там URL подключения к базе и нажать Import, чтобы все значения подтянулись из URL.

  7. Если ваше подключение требует SSL, то ставим галочку «Use SSL», выбираем режим и загружаем нужные ключи.

  8. Затем нажимаем «Test Connection» и «Create connection» в верхнем правому углу, чтобы проверить и сохранить подключение.

Окно подключения внешней базы данных
Окно подключения внешней базы данных

Далее при желании можно поменять настройки разрешений (Permissions).

  • По умолчанию стоит галочка «Allow Data Write/Edit», т. е. разрешается создать/редактировать данные в этой базе. Но вы можете и убрать ее, чтобы оставить только просмотр данных.

  • Также по умолчанию выключена галочка «Allow Schema Change». Это значит, что не разрешено изменение схемы базы: создание, изменение или удаление таблиц и столбцов.

Для завершения подключения нажимаем «Add Source». Если всё ок, то внешняя база со всеми таблицами появится в сайдбаре. И для каждой таблицы сразу будет добавлено одно Grid View по умолчанию.

Интересно, что хотя при выключенной опции «Allow Schema Change» вы не можете добавить обычные столбцы в таблицы этой базы, но всё-таки часть столбцов можно добавить: это Lookup, Formula, Rollup, QR Code, Barcode и Button.

Дело в том, что это виртуальные поля — они не являются полями таблиц в техническом смысле и не добавляют ничего к самой базе.

В остальном, не считая ограничений, наложенных настройками разрешений (Permission), работа с внешними базами ничем не отличается от работы с таблицами основной базы.

❯ Импорт данных

На странице действий с базой есть опция Import Data (Импортировать данные). Доступные варианты источников импорта:

  • Airtable

  • CSV

  • Json

  • Excel

При этом для импортированных данных будет создана новая таблица.

Отметим, что импортировать во внешнюю базу можно только, если у нее включена опция «Allow Schema Change».

Также отметим, что это именно разовый импорт. И если вам вместо этого нужна постоянная автоматическая синхронизация данных например из Airtable, то она доступна только в платной облачной версии NocoDB.

❯ Документы

Также NocoDB позволяет создавать текстовые документы, аналогично Notion. Это можно сделать по клику на «Create New Document» на стартовом экране или же на странице базы нажать «Create New» и затем выбрать Document.

Создание документа в NocoDB (изображение из официального блога)
Создание документа в NocoDB (изображение из официального блога)

❯ Настройки базы

В боковом меню есть пункт Settings, который открывает раздел с настройками базы. Там доступно:

  • Invite Members to Base — позволяет приглашать других пользователей к этой базе и настраивать их роли.

  • Manage Data Sources — управление списком внешних источников, которые активны в данной базе.

  • Base Integrations — настройка всех интеграций. В случае с бесплатной версией это могут быть только подключения к внешним базам (MySQL и PostgreSQL).

  • MCP Server — добавление собственного MCP-сервера для работы с вашим NocoDB.

  • General — раздел с общими настройками базы.

В General отдельного внимания заслуживает вкладка «Visibility & Data Handling» — опции для настройки отображения данных:

  • Show M2M Tables — включить отображение таблиц со связями многие-ко-многим (по умолчанию они не показываются).

  • Show NULL in Cells — показывать явно, если ячейка содержит NULL.

  • Show NULL and EMPTY in Filter — включает, что в фильтре будут отдельные опции для NULL и для пустой строки (по умолчанию в фильтре это считается как одно и то же).

Настройки отображения данных
Настройки отображения данных

❯ Глобальные опции

При клике на иконку профиля в нижнем левом углу можно увидеть разные глобальные опции:

  • Experimental Features — можно включить экспериментальные функции, которые пока находится в тестовом режиме.

  • Keyboard Shortcuts — горячие клавиши.

  • Admin Panel — админ-панель с некоторыми глобальными настройками системы и сводной информацией.

  • API Tokens — быстрый переход на страницу настройки API ключей.

  • Language — настройки языка интерфейса.

  • Appearance — переключение между светлой и темной темой.

  • Account Setting — настройки аккаунта, в т. ч. имя, фото, API токены, MCP-сервер и внешние интеграции.

❯ Вопрос лицензии: NocoDB это не Open Source

Вы могли заметить, что в статье мы избегали термина Open Source (открытый код) в отношении NocoDB.

Это не спроста — недавно разработчики сменили модель распространения программы с Open Source на Fair Code (Sustainable Use License), что можно перевести как «Справедливый код (Лицензия устойчивого использования)».

В связи с этим возникает вопрос — можно ли по прежнему ставить Ноко на свой сервер, модифицировать код и пользоваться программой бесплатно без ограничений?

Посмотрим, что написано в новой лицензии:

  • Можно использовать или изменять программное обеспечение только для собственных внутренних бизнес-целей либо для некоммерческого или личного использования.

  • Можно распространять программное обеспечение или предоставлять его другим лицам только бесплатно и исключительно в некоммерческих целях.

Получается, что для тех, кто использует NocoDB для личных нужд или для нужд своего бизнеса — ничего не меняется. Можно по прежнему хостить его на своих серверах, используя исходный код.

Изменилось только то, что теперь лицензия прямо запрещает продавать Ноко как часть своего продукта.

❯ Заключение

Как видно, NocoDB это многофункциональный инструмент, который можно использовать как полноценный конструктор информационной системы для бизнеса, но также и просто как удобный UI-интерфейс для визуальной работы с базами данных.

Программа в разработке уже давно, поэтому она дошла до стабильного состояния, когда дизайн выглядит приятно, а баги почти не встречаются.

И хотя формально это уже не Open Source, сервис всё равно можно использовать полностью бесплатно с установкой на собственном сервере.

Будем рады, если статья оказалась полезной и вы тоже найдёте, как с пользой задействовать NocoDB в своей работе.

Чтобы не пропустить следующую статью: https://t.me/nickneustroev_blog


Новости, обзоры продуктов и конкурсы от команды Timeweb.Cloud — в нашем Telegram-канале

Комментарии (4)


  1. aborouhin
    06.05.2026 08:27

    IMHO, они по функционалу и UX и так сильно проигрывали Grist, а теперь, получается, ещё и лицензия проблемная :(

    Ну а к "альтернативе Airtable" ближе всего SeaTable (тоже проприетарная лицензия, но был довольно щедрый free tier), там прямо под копирку фичи продублированы.


    1. nickneustroev Автор
      06.05.2026 08:27

      Про Grist и SeaTable слышал, тоже вроде крутые инструменты. Но правильно понимаю, что там нельзя подключать внешние базы, типа PostgreSQL? Если так, то это всё-таки другое. Мне нравится использовать Ноко именно как просмотрщик для БД моих разных проектов.

      Я бы не назвал лицензию Ноко проблемной. Они просто приструнили тех, кто выдавал их продукт за свой и наживался на этом. Для обычных юзеров ничего не поменялось, если не ошибаюсь.


      1. aborouhin
        06.05.2026 08:27

        Я последний раз на эти инструменты смотрел года два назад, может что-то и поменялось. Но по состоянию на то время - у Grist под капотом SQLite, так что с базой можно работать сторонними инструментами. Но использовать именно как фронтенд к внешним базам данных ни один из упомянутых мной продуктов было нельзя, только через импорт. Но если мы раз говорим об "альтернативе Airtable", так Airtable вроде тоже так не умеет :)

        По лицензии надо разобраться, что они считают внутренними бизнес-целями. Скажем, если я делаю какую-нибудь систему учета заказов, которая предусматривает возможность доступа клиентов для создания заявки или просмотра статуса своей заявки, - это внутреннее использование или уже нет? Обычно для сохранения open-source, но при этом отсечения коммерческих конкурентов берут AGPL, а тут по какой-то причине решили создать своё...


        1. nickneustroev Автор
          06.05.2026 08:27

          Согласен, в плане чисто альтернативы Airtable все инструменты норм, и тут Noco может даже не самый функциональный вариант.

          систему учета заказов, которая предусматривает возможность доступа клиентов для создания заявки или просмотра статуса своей заявки

          Так понимаю, что если вы создаёте систему для одной конкретной компании, то всё ок. Но если создается система, которая продаётся как SaaS или коробочный продукт, то тут уже надо доплачивать Ноко.

          В целом да, понятно, что это хуже чем Open Source. Кажется, всё больше подобных проектов уходят от к ограниченным кастомным лицензиям, хоть и оставляют исходный код.