Docker через загрузку образов из файла

Внимание

Дисклеймер.

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

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

Подготовка

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

  • Обновите существующий список пакетов Ubuntu. Команда:

    sudo apt update
    
  • Установите Docker.

  • Установите Docker Compose (версия выше 1.29).

  • Настройте разрешения для Docker Compose. Пример команды:

    sudo chmod +x /usr/local/bin/docker-compose
    

Дистрибутив:

  • Заранее получите и скачайте образы Docker с дистрибутивом продукта Юниверс.

Установка

  1. Скачайте и распакуйте из архива дистрибутива архивы образов Docker. Пример: universe_mdm_ee_backend_docker_v6.14.zip и universe_mdm_ee_frontend_docker_v6.14.zip. Внутри содержатся образы Docker с расширением .tar.

  2. Распакуйте на сервер содержимое вышеуказанных архивов.

  3. Запустите Docker.

  4. Запустите загрузку образов:

docker load < /opt/universe_mdm_ee_backend_docker_v6.14.tar
docker load < /opt/universe_mdm_ee_frontend_docker_v6.14.tar
  1. Дождитесь завершения.

  2. Создайте файлы конфигурации docker-compose.yaml, .env. Содержимое файлов см. ниже.

  • Расположение файлов на сервере может быть любым. Файлы конфигурации должны читаться через Docker compose.

  1. Укажите имя образа и тег для файла .env. Используйте один из способов:

  • Измените имя и тег в параметрах BACKEND_IMAGE и FRONTEND_IMAGE файла .env. Сохраните изменения.

  • Используйте команду. Пример:

docker image tag repo.tddev.ru/unidata-mdm/backend:v6.3 universe_mdm_ee_backend:v6.14
  1. Отредактируйте остальные требуемые параметры в файлах docker-compose.yaml, .env. Сохраните изменения.

  2. Перейдите в каталог с кодом. Пример команды:

cd universe-mdm-deploy
  1. Для запуска системы используйте команду:

docker-compose up -d
  1. При запуске интерфейса система потребует лицензию. Установите вашу лицензию.

По умолчанию пользовательский интерфейс доступен для просмотра на localhost:8082.

Логин и пароль по умолчанию: admin/ admin. После первого входа в систему необходимо сменить пароль.

Обязательные файлы конфигурации

Указанные ниже файлы должны быть созданы вручную.

Пример файла .env:

BACKEND_IMAGE=docker.universe-data.ru/unidata-ee/backend:release-6-14-1c89bd8a
FRONTEND_IMAGE=docker.universe-data.ru/unidata-ee/frontend:v6.14.0

OPENSEARCH_HTTP_OUTER_PORT=19201

MDM_POSTGRES_USER=postgres
MDM_POSTGRES_PASSWORD=postgres
MDM_POSTGRES_DB_NAME=postgres
POSTGRES_OUTER_PORT=15431

FRONTEND_PORT=8082
BACKEND_PORT=9081

GUEST_MODE=false

#TIMEZONE=Europe/Moscow

RESTORE_EMAIL_ENABLED=false
RESTORE_EMAIL_SERVER_HOST=localhost
RESTORE_EMAIL_SERVER_PORT=5025
RESTORE_EMAIL_USERNAME=universe@example.com
RESTORE_EMAIL_PASSWORD=password
RESTORE_EMAIL_FRONTEND_URL=''
RESTORE_EMAIL_SSL_ENABLE=true
RESTORE_EMAIL_STARTTLS_ENABLE=false

LDAP_GENERAL_USERS_GROUP_NAME=general-ldap-users-group

#nginx.conf
BACKEND_ADDRESS=http://mdm:8080
CLIENT_MAX_BODY_SIZE=100m
PROXY_SEND_TIMEOUT=600s
PROXY_READ_TIMEOUT=600s
SEND_TIMEOUT=600s

### Settings for cluster (run command: docker-compose -f docker-compose-cluster.yaml up -d) ###
FRONTEND_PORT_2=8083
BACKEND_PORT_2=9082
BACKEND_ADDRESS_2=http://mdm2:8080
CACHE_AUTO_DETECTION_ENABLED=true
CACHE_GROUP=unidata
CACHE_PASSWORD=password
CACHE_PORT=5701
CACHE_PORT_AUTOINCREMENT=false
CACHE_TCP_IP_ENABLED=true
CACHE_TCP_IP_MEMBERS=mdm,mdm2
CACHE_PUBLIC_ADDRESS=mdm:5701
CACHE_PUBLIC_ADDRESS_2=mdm2:5701
SYSTEM_NODE_ID=node0
SYSTEM_NODE_ID_2=node1
### Settings for cluster ###

#ActiveMQ
ACTIVEMQ_ADMIN_LOGIN=admin
ACTIVEMQ_ADMIN_PASSWORD=admin

Где BACKEND_IMAGE и FRONTEND_IMAGE: имена Docker-образов и теги версии. Тег указывается после двоеточия. Пример значений:

  • BACKEND_IMAGE=universe_mdm_ee_backend:v6.14

  • FRONTEND_IMAGE=universe_mdm_ee_frontend:v6.14

Пример файла docker-compose.yaml:

 services:

 setup_json:
   image: docker.universe-data.ru/mirror/chatwork/jq:latest
   entrypoint: >
     sh -c "
     cd /opt/json_configs;
     [ ! -z ${OVERRIDE_JSON:-''} ] &&
     jq -s '.[0] * .[1]' customer.json ${OVERRIDE_JSON}
     > ../customer.json ||
     cp customer.json ../customer.json"
   volumes:
     - ./:/opt

 ui:
   image: ${FRONTEND_IMAGE}
   restart: always
   ports:
     - ${FRONTEND_PORT}:80
   networks:
     - mdm_network
   links:
     - mdm
   volumes:
     - ${FRONTEND_UE:-/dev/null}:/usr/share/nginx/html/CUX
     - ./customer.json:/usr/share/nginx/html/customer.json
   environment:
     BACKEND_ADDRESS: ${BACKEND_ADDRESS}
     CLIENT_MAX_BODY_SIZE: ${CLIENT_MAX_BODY_SIZE}
     PROXY_SEND_TIMEOUT: ${PROXY_SEND_TIMEOUT}
     PROXY_READ_TIMEOUT: ${PROXY_READ_TIMEOUT}
     SEND_TIMEOUT: ${SEND_TIMEOUT}
     TZ: ${TIMEZONE:-UTC}
   depends_on:
     setup_json:
       condition: service_completed_successfully

 mdm:
   image: ${BACKEND_IMAGE}
   restart: always
   ports:
     - ${BACKEND_PORT}:8080
   networks:
     - mdm_network
   environment:
     GUEST_MODE: ${GUEST_MODE}
     POSTGRES_ADDRESS: postgres-mdm:5432
     POSTGRES_USERNAME: ${MDM_POSTGRES_USER}
     POSTGRES_PASSWORD: ${MDM_POSTGRES_PASSWORD}
     DATABASE_NAME: ${MDM_POSTGRES_DB_NAME}
     SEARCH_CLUSTER_ADDRESS: opensearch-mdm:9200
     SEARCH_CLUSTER_NAME: docker-cluster
     EMAIL_ENABLED: ${RESTORE_EMAIL_ENABLED}
     EMAIL_SERVER_HOST: ${RESTORE_EMAIL_SERVER_HOST}
     EMAIL_SERVER_PORT: ${RESTORE_EMAIL_SERVER_PORT}
     EMAIL_USERNAME: ${RESTORE_EMAIL_USERNAME}
     EMAIL_PASSWORD: ${RESTORE_EMAIL_PASSWORD}
     EMAIL_FRONTEND_URL: ${RESTORE_EMAIL_FRONTEND_URL}
     EMAIL_SSL_ENABLE: ${RESTORE_EMAIL_SSL_ENABLE}
     EMAIL_STARTTLS_ENABLE: ${RESTORE_EMAIL_STARTTLS_ENABLE}
     TZ: ${TIMEZONE:-UTC}
     LDAP_GENERAL_USERS_GROUP_NAME: ${LDAP_GENERAL_USERS_GROUP_NAME}
   depends_on:
     postgres-mdm:
       condition: service_healthy
     opensearch-mdm:
       condition: service_healthy

 postgres-mdm:
   image: docker.universe-data.ru/mirror/postgres16.3-tsdb2.15.2
   restart: always
   environment:
     POSTGRES_DB: ${MDM_POSTGRES_DB_NAME}
     POSTGRES_USER: postgres
     POSTGRES_PASSWORD: postgres
     MDM_POSTGRES_USER: ${MDM_POSTGRES_USER}
     MDM_POSTGRES_PASSWORD: ${MDM_POSTGRES_PASSWORD}
     TZ: ${TIMEZONE:-UTC}
   ports:
     - ${POSTGRES_OUTER_PORT}:5432
   networks:
     - mdm_network
   volumes:
     - ./init-db.sh:/docker-entrypoint-initdb.d/initdb.sh
     - mdm-postgres-data:/var/lib/postgresql/data
   command: postgres -N 350 -c max_prepared_transactions=350 -c shared_preload_libraries='timescaledb'
   healthcheck:
     test: ["CMD-SHELL", "pg_isready -U postgres -d $MDM_POSTGRES_DB_NAME"]
     interval: 10s
     timeout: 1s
     retries: 20

 opensearch-mdm:
   image: docker.universe-data.ru/mirror/opensearchproject/opensearch:2.14.0
   restart: always
   environment:
     - "OPENSEARCH_JAVA_OPTS=-Xms512m -Xmx512m"
     - "discovery.type=single-node"
     - "DISABLE_SECURITY_PLUGIN=true"
     - "TZ=${TIMEZONE:-UTC}"
   volumes:
     - mdm-opensearch-data:/usr/share/opensearch/data
     - ./hunspell:/usr/share/opensearch/config/hunspell/
     - ./synonyms.txt:/usr/share/opensearch/config/synonyms.txt
     - ./plugins:/usr/share/opensearch/plugins-for-install/
     - ./opensearch-install-plugins-and-start.sh:/usr/share/opensearch/opensearch-install-plugins-and-start.sh
   entrypoint: /usr/share/opensearch/opensearch-install-plugins-and-start.sh
   ulimits:
     memlock:
       soft: -1
       hard: -1
   ports:
     - ${OPENSEARCH_HTTP_OUTER_PORT}:9200
   networks:
     - mdm_network
   healthcheck:
     test: >
       bash -c "curl http://localhost:9200 | grep '\"cluster_name\"'"
     interval: 10s
     timeout: 2s
     retries: 20

volumes:
 mdm-postgres-data:
   driver: local
 mdm-opensearch-data:
   driver: local

networks:
 mdm_network:
   driver: bridge