Регистрация

Postgresql | Установка с помощью Portainer

Установка базы данных Postgresql с нуля с помощью Portainer на сервере под управлением Ubuntu 22.04 LTS.

После активации удаленного сервера и подключения к нему выполните указанные команды по очереди.

Установка Docker и Docker compose

  • Проверяем и удаляем предыдущие части установок docker и всего с ним связанного
ShellScript
for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done
  • Получаем ключи для подключения к репозиторию Docker
ShellScript
# Add Docker's official GPG key:
sudo apt-get update
sudo apt-get install ca-certificates curl gnupg
sudo install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
sudo chmod a+r /etc/apt/keyrings/docker.gpg

# Add the repository to Apt sources:
echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
  $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
  sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
  • Устанавливаем необходимые пакеты одной командой
ShellScript
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin docker-compose -y
  • Проверяем, что docker, docker compose и docker-compose установлены на вашем сервере.
    (Мы должны получить ответ с версиями этих утилит)
ShellScript
docker version
docker compose version
docker-compose version

Установка Portainer

  • Запускаем portainer на сервере с помощью команды:
ShellScript
docker volume create portainer_data
docker run -d -p 8000:8000 -p 9443:9443 --name portainer --restart=always -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer-ce:latest
  • После выполнения всех команд переходим по адресу: https://ip-вашего-сервера:9443
  • Соглашаемся с предупреждением от браузера и переходим к сервису.
    (браузер будет ругаться на сертификат безопасности. Мы ведь переходим по прямому адресу сервера + порт по протоколу https, а браузеры считают такую активность небезопасной)
  • Задаем логин и пароль для администратора.
  • Вы успешно установили Portainer на свой сервер.

Установка Postgresql и подключение

  • Создаем Stack в Portainer
  • В поле конфигурации вставляем код:
YAML
version: "3.8"

volumes:
  postgres_data:

services:
  postgres:
    image: postgres
    container_name: postgres
    restart: always
    environment:
      POSTGRES_USER: ${POSTGRES_USER}
      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
      POSTGRES_DB: ${POSTGRES_DB}
    healthcheck:
      test: ['CMD-SHELL', 'pg_isready -h localhost -U ${POSTGRES_USER} -d ${POSTGRES_DB}']
      interval: 5s
      timeout: 5s
      retries: 10
    ports:
      - "5432:5432"
    volumes:
      - postgres_data:/var/lib/postgresql/data

networks:
  default:
    external:
      name: general
  • В поле с переменными вставляем следующие переменные в режиме Advanced Mode
YAML
POSTGRES_USER='имя пользователя'
POSTGRES_PASSWORD='надежный пароль'
POSTGRES_DB='база данных по умолчанию'
  • После запуска Стека база данных будет доступна по адресу ip-вашего-сервера:порт-который-вы-определили
  • Логин, пароль и базу данных для подключения вы задали в соответствующих переменных чуть выше
  • Для одновременного запуска нескольких экземпляров Postgresql на одном сервере не забудьте менять у них внешний порт и директорию для хранения постоянных файлов

Разделы

Никита Рянский, Автор блога

Никита Рянский

Фрилансер
Разработчик
Автор блога
Подписывайтесь
и пишите для заказа разработки, настройки и консультации

Оставьте комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *