Установка базы данных 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 на одном сервере не забудьте менять у них внешний порт и директорию для хранения постоянных файлов
Оставьте комментарий