Перейти к содержанию

Запуск Picodata

В данном разделе приведена информация по запуску отдельного инстанса Picodata на физическом оборудовании или в виртуальной среде.

Инстанс — экземпляр приложения Picodata, из которых состоит кластер. Picodata может создать кластер, состоящий всего из одного экземпляра/инстанса.

Минимальный вариант запуска

В самом простом случае запуск инстанса сводится к выполнению команды picodata run без каких-либо параметров:

picodata run

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

Читайте далее:

Запуск нескольких инстансов

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

  • рабочую директорию (--instance-dir)
  • сетевой адрес (--iproto-listen)
  • адрес одного или нескольких соседних инстансов (--peer)
  • адрес сервера PostgreSQL (--pg-listen)

Полный перечень возможных параметров запуска и их описание содержатся в разделе Аргументы командной строки, а также в выводе команды picodata run --help.

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

picodata run --instance-dir ./data/i1 --iproto-listen 127.0.0.1:3301 --pg-listen 127.0.0.1:4327
picodata run --instance-dir ./data/i2 --iproto-listen 127.0.0.1:3302 --pg-listen 127.0.0.1:4328 --peer 127.0.0.1:3301

Обратите внимание на различия в запуске инстансов:

  • каждый инстанс использует свою рабочую директорию и сетевой адрес
  • в отсутствие параметра --peer запуск инстанса приводит к созданию нового кластера. Чтобы инстансы добавлялись в уже существующий кластер в этом параметре передается адрес первого инстанса

Читайте далее:

Запуск с помощью Docker Compose

Picodata поддерживает запуск при помощи инструментария Docker Compose и предоставляет пример файла docker-compose.yml для запуска тестового кластера. Этот способ удобен тем, что позволяет запускать Picodata без необходимости установки пакетов или сборки из исходного кода.

Для развертывания тестового кластера данным способом выполните следующие шаги.

Убедитесь, что у вас установлены Docker, Docker Compose, а также что системная служба docker запущена, см Docker Compose overview

Скачайте файл docker-compose.yml, который описывает тестовый кластер из 4-х инстансов:

curl -O https://git.picodata.io/core/picodata/-/raw/master/docker/docker-compose.yml?inline=false

Создайте директорию для рабочих файлов проекта и задайте путь к Docker-репозиторию Picodata:

mkdir pico
export REGISTRY=docker-public.binary.picodata.io

Запустите контейнеры:

docker-compose up -d

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

Для подключения к консоли администратора используйте команду:

picodata admin pico/data/picodata-1-1/admin.sock

Для подключения к пользовательской консоли по протоколу PostgreSQL используйте команду:

psql postgres://admin@127.0.0.1:4327

Пароль администратора T0psecret задан через переменную окружения PICODATA_ADMIN_PASSWORD, см. docker-compose.yml:17

Безопасный запуск

Для обеспечения мер безопасности рекомендуется организовать хранение пароля для внутреннего системного пользователя pico_service в отдельном файле .picodata-cookie, который следует поместить в рабочую директорию инстанса. Пароль пользователя pico_service используется в рамках всего кластера, поэтому его нужно задать одинаковым для всех инстансов кластера до их первого запуска (соответственно, следует также заранее подготовить рабочие директории инстансов).

Дополнительно, в опции --audit явно укажите способ вывода журнала аудита.

Также рекомендуется использовать опцию --shredding, которая обеспечивает безопасное удаление рабочих файлов.

Пример команд, реализующих безопасный запуск:

mkdir data
echo "shAreDs3cr3t" > data/.picodata-cookie
chmod 600 data/.picodata-cookie
picodata run --instance-dir=data --audit audit.log --shredding

Завершение работы и обработка сигналов

Способ завершения процесса picodata может отличаться в зависимости от того, как этот процесс был запущен.

Если инстанс Picodata был запущен через Ansible, то процесс инстанса управляется менеджером Systemd, причем имя службы инстанса формируется по схеме <cluster_name>@<instance_name>.service. Соответственно, для остановки службы введите команду:

Пример для службы `test@default-1000.service`, запущенной администратором хоста
sudo systemctl stop test@default-1000.service

или:

Пример для службы `test@default-1000.service`, запущенной от имени обычного пользователя хоста
systemctl --user stop test@default-1000.service

Если инстанс Picodata был запущен локально, но обернут в виде юнита/службы Systemd, то для остановки инстанса нужно сначала определить имя службы, которая управляет процессом инстанса. Это тем более важно, если таким образом на одном хосте выполняется несколько инстансов Picodata.

Для начала выясните список запущенных процессов Picodata:

ps -o'pid,args,unit' `pgrep picodata`

В колонке UNIT будет указано имя службы Systemd, которую можно остановить через systemctl stop. Если имя службы выглядит как user@1000.service (где 1000 — UID пользователя, из-под которого был запущен процесс), то инстанс был запущен напрямую из консоли, скрипта или как-либо еще без задействования Systemd. В таком случае для остановки инстанса нужно послать сигнал завершения его процессу.

Для безопасного завершения процесса picodata используйте следующие сигналы:

  • SIGINT. kill -2 [pid]
  • SIGTERM. kill -15 [pid]

Для ротирования файлов журнала процесса picodata (прекращения записи в прежний файл) используйте SIGHUP:

  • SIGHUP. kill -1 [pid]

Если инстанс был запущен непосредственно в терминале, с одновременным выводом в него диагностических сообщений (stdout), то достаточно нажать сочетание клавиш Ctrl+C , что эквивалентно отправке процессу SIGINT. После этого процесс инстанса будет корректно завершен.