Перейти к основному содержанию
Контейнеры Docker предназначены для продакшен-размещения или самостоятельного хостинга; для участия в разработке ознакомьтесь с разделом Локальная установка.

Обзор

Это руководство предоставляет пошаговые инструкции по установке и настройке приложения Twenty с помощью Docker Compose. Цель заключается в том, чтобы сделать процесс простым и избежать распространенных ошибок, которые могут привести к сбоям в настройке. Важно: изменяйте только те настройки, которые явно упоминаются в этом руководстве. Изменение других конфигураций может привести к проблемам. См. документацию Настройка переменных окружения для расширенной конфигурации. Все переменные окружения должны быть задекларированы в файле docker-compose.yml на уровне сервера и / или рабочего потока в зависимости от переменной.

Системные требования

  • ОЗУ: Убедитесь, что в вашей среде не менее 2 ГБ ОЗУ. Недостаток памяти может вызвать сбой процессов.
  • Docker и Docker Compose: убедитесь, что оба установлены и обновлены.

Вариант 1: Скрипт с одной строкой

Установите последнюю стабильную версию Twenty одной командой:
bash <(curl -sL https://raw.githubusercontent.com/twentyhq/twenty/main/packages/twenty-docker/scripts/install.sh)
Для установки конкретной версии или ветки:
VERSION=vx.y.z BRANCH=branch-name bash <(curl -sL https://raw.githubusercontent.com/twentyhq/twenty/main/packages/twenty-docker/scripts/install.sh)
  • Замените x.y.z на желаемый номер версии.
  • Замените branch-name на имя ветки, которую вы хотите установить.

Вариант 2: Ручные шаги

Выполните следующие шаги для ручной настройки.

Шаг 1: Настройте файл среды

  1. Создайте файл .env Скопируйте пример файла окружения в новый .env файл в вашем рабочем каталоге:
    curl -o .env https://raw.githubusercontent.com/twentyhq/twenty/refs/heads/main/packages/twenty-docker/.env.example
    
  2. Создайте секретные токены Выполните следующую команду для генерации уникальной случайной строки:
    openssl rand -base64 32
    
    Внимание: держите это значение в секрете / не делитесь им.
  3. Обновите файл .env Замените значение плейсхолдера в вашем файле .env на сгенерированный токен:
    APP_SECRET=first_random_string
    
  4. Установите пароль для Postgres Обновите значение PG_DATABASE_PASSWORD в файле .env, используя надежный пароль без специальных символов.
    PG_DATABASE_PASSWORD=my_strong_password
    

Шаг 2: Получите файл Docker Compose

Скачайте файл docker-compose.yml в ваш рабочий каталог:
curl -o docker-compose.yml https://raw.githubusercontent.com/twentyhq/twenty/refs/heads/main/packages/twenty-docker/docker-compose.yml

Шаг 3: Запустите приложение

Запустите Docker-контейнеры:
docker compose up -d

Шаг 4: Доступ к приложению

Если вы размещаете twentyCRM на своем компьютере, откройте ваш браузер и перейдите на http://localhost:3000. Если вы размещаете это на сервере, убедитесь, что сервер запущен и что все в порядке с
curl http://localhost:3000

Конфигурация

Открыть доступ к Twenty из внешней сети

По умолчанию Twenty работает на localhost на порту 3000. Чтобы получить доступ через внешний домен или IP-адрес, необходимо настроить SERVER_URL в вашем .env файле.

Понимание SERVER_URL

  • Протокол: используйте http или https в зависимости от вашей настройки.
    • Используйте http, если SSL не настроен.
    • Используйте https, если SSL настроен.
  • Домен/IP: это имя домена или IP-адрес, где ваше приложение доступно.
  • Порт: указывайте номер порта, если вы не используете порты по умолчанию (80 для http, 443 для https).

Требования к SSL

SSL (HTTPS) требуется для правильной работы некоторых функций браузера. Хотя эти функции могут работать во время разработки на локальном компьютере (поскольку браузеры обрабатывают localhost иначе), правильная настройка SSL необходима при размещении Twenty на регулярном домене. Например, API буфера обмена может потребовать защищенный контекст - некоторые функции, такие как кнопки копирования в приложении, могут не работать без включения HTTPS. Мы настоятельно рекомендуем настроить Twenty за обратным прокси-сервером с прекращением SSL для оптимальной безопасности и функциональности.

Настройка SERVER_URL

  1. Определите ваш URL-адрес доступа
    • Без обратного прокси (Прямой доступ): Если вы получаете доступ к приложению напрямую без использования обратного прокси:
      SERVER_URL=http://ваш-домен-или-ip:3000
      
    • С обратным прокси (Стандартные порты): Если вы используете обратный прокси, такой как Nginx или Traefik, и у вас настроен SSL:
      SERVER_URL=https://ваш-домен-или-ip
      
    • С обратным прокси (Не стандартные порты): Если вы используете нестандартные порты:
      SERVER_URL=https://ваш-домен-или-ip:ваш-порт
      
  2. Обновите файл .env Откройте ваш файл .env и обновите SERVER_URL:
    SERVER_URL=http(s)://ваш-домен-или-ip:ваш-порт
    
    Примеры:
    • Прямой доступ без SSL:
      SERVER_URL=http://123.45.67.89:3000
      
    • Доступ через домен с SSL:
      SERVER_URL=https://mytwentyapp.com
      
  3. Перезапустите приложение Для применения изменений перезапустите контейнеры Docker:
    docker compose down
    docker compose up -d
    

Рассмотрения

  • Конфигурация обратного прокси: Убедитесь, что ваш обратный прокси передаёт запросы на правильный внутренний порт (3000 по умолчанию). Настройте завершение SSL и все необходимые заголовки.
  • Настройки брандмауэра: Откройте необходимые порты в вашем брандмауэре для обеспечения внешнего доступа.
  • Последовательность: Значение SERVER_URL должно соответствовать тому, как пользователи обращаются к вашему приложению в своих браузерах.

Сохранение данных

  • Тома данных: Конфигурация Docker Compose использует тома для сохранения данных базы данных и хранилища сервера.
  • Среды без состояния: Если развёртывание осуществляется в бесстатном окружении (например, некоторых облачных сервисах), настройте внешнее хранилище для сохранения данных.

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

Регулярные резервные копии защищают данные вашей CRM от потери.

Создание резервной копии базы данных

docker exec twenty-postgres pg_dump -U postgres twenty > backup_$(date +%Y%m%d).sql

Автоматизируйте ежедневное резервное копирование

Добавьте в свой crontab (crontab -e):
0 2 * * * docker exec twenty-postgres pg_dump -U postgres twenty > /backups/twenty_$(date +\%Y\%m\%d).sql

Восстановление из резервной копии

  1. Остановите приложение:
docker compose stop twenty-server twenty-front
  1. Восстановите базу данных:
docker exec -i twenty-postgres psql -U postgres twenty < backup_20240115.sql
  1. Перезапустите службы:
docker compose up -d

Лучшие практики резервного копирования

  • Регулярно проверяйте восстановление — убедитесь, что резервные копии действительно работают
  • Храните резервные копии вне площадки — используйте облачное хранилище (S3, GCS и т. д.)
  • Шифруйте конфиденциальные данные — защищайте резервные копии с помощью шифрования
  • Храните несколько копий — сохраняйте ежедневные, еженедельные и ежемесячные резервные копии

Устранение неполадок

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