8000 GitHub - GoldinEA/bitrixdock: BitrixDock - это готовое Docker окружение для Bitrix CMS :dart:
[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Skip to content

GoldinEA/bitrixdock

 
 

Repository files navigation

Alt text

Рекомендации:

  • Не запускать через 0.0.0.0 (оптимально через 127.0.0.1)

Отличия от оригинальной версии:

  • Убраны все версии php ниже 8.0, остальное переведено на alpine (тестировал только 8.3 - остальное по аналогии)
  • По умолчанию включен xdebug.
  • Добавлен mailhog, чтобы было удобнее отлаживать почту.
  • Nginx переведен на alpine версию образа для экономии места и ресурсов

Todo:

  • добавить codeception
  • возможно перевести с adminer на phpmyadmin
  • Добавить redis и bitrix-push сервер, чтобы работало

BitrixDock

BitrixDock позволяет легко и просто запускать Bitrix CMS на Docker.

⚠️ Этот проект, для того чтобы посмотреть демо Битрикса, а не запустить продакшн сайт. Примеры реальных продакшн сайтов ищите внизу страницы.

Введение

BitrixDock запускает демо Битрикса предоставляя готовые сервисы PHP, NGINX, MySQL и многие другие.

Преимущества данной сборки

  • Сервис PHP запакован в отдельный образ, чтобы избавить разработчиков от долгого компилирования.
  • Остальные сервисы так же "причёсаны" и разворачиваются моментально.
  • Ничего лишнего.

Требования

  • Git
  • Docker
  • Docker Compose v2

Порядок разработки в Windows

Если вы работаете в Windows, то все заводится на штатном WSL2 + Docker Desktop

Как альтернативный вариант - можно поднять виртуальную машину (через Vagrant, VirtualBox, VMware и тп), тестировалось на Ubuntu 18.04. Ваш рабочий проект должен хранится в двух местах, первое — локальная папка с проектами на хосте (открывается в IDE), второе — виртуальная машина (например /var/www/bitrix). Проект на хосте мапится в IDE к гостевой OC.

Автоматическая установка

Для разворачивания на Linux машине

curl -fsSL https://raw.githubusercontent.com/GoldinEA/bitrixdock/master/install.sh?$(date +%s) -o install.sh && chmod +x install.sh && sh install.sh

Ручная установка

Выполните настройку окружения

Скопируйте файл .env_template в .env

cp -f .env_template .env

⚠ Если у вас мак, удалите строчку /etc/localtime:/etc/localtime/:ro из docker-compose.yml

По умолчанию используется nginx, php 8.3, mysql. Настройки можно изменить в файле .env. Также можно задать путь к каталогу с сайтом и параметры базы данных MySQL.

COMPOSE_PROJECT_NAME=bitrixdock  # Имя проекта. Используется для наименования контейнеров
PHP_VERSION=php74                # Версия php
WEB_SERVER_TYPE=nginx            # Веб-сервер nginx/apache
DB_SERVER_TYPE=mysql             # Сервер базы данных mysql/percona
MYSQL_DATABASE=bitrix            # Имя базы данных
MYSQL_USER=bitrix                # Пользователь базы данных
MYSQL_PASSWORD=123               # Пароль для доступа к базе данных
MYSQL_ROOT_PASSWORD=123          # Пароль для пользователя root от базы данных
INTERFACE=0.0.0.0                # На данный интерфейс будут проксироваться порты (не рекомендуется ставить 0.0.0.0)
SITE_PATH=./www                  # Путь к директории Вашего сайта
REDIS_SEC_KEY=sasdfasdf          # Секретный ключ для Redis сервисов

Если у вас всё получилось, будем благодарны за звёздочку :) Ошибки ждём в issue Приятной работы!

Запуск и остановка bitrixdock

Запуск

docker compose -p bitrixdock up -d

Чтобы проверить, что все сервисы запустились посмотрите список процессов docker ps. Посмотрите все прослушиваемые порты, должны быть 80, 11211, 9000 netstat -plnt. Откройте IP машины в браузере.

Остановка

docker compose -p bitrixdock stop

Полное удаление

    docker compose -p bitrixdock down

Как заполнять подключение к БД

db

Примечание

  • По умолчанию стоит папка ./www (папка внутри репозиториия)
  • В настройках подключения требуется указывать имя docker compose сервиса, например для подключения к базе нужно указывать "db", а не "localhost". Пример конфига с подключением к mysql и memcached.
  • Для загрузки резервной копии в контейнер используйте команду: cat /var/www/bitrix/backup.sql | docker exec -i db /usr/bin/mysql -u root -p123 bitrix
  • Если контейнер php-fpm выдает ошибку "failed to create new listening socket: socket(): Address family not supported by protocol", то необходимо включить поддержку IPv6 в системе. Например в Ubuntu 22.04 — закомментировать строку в конфиге GRUB "GRUB_CMDLINE_LINUX="ipv6.disable=1"

Отличие от виртуальной машины Битрикс

Виртуальная машина от разработчиков Битрикс решает ту же задачу, что и BitrixDock - предоставляет готовое окружение. Разница лишь в том, что Docker намного удобнее, проще и легче в поддержке.

Как только вы запускаете виртуалку, Docker сервисы автоматически стартуют, т.е. вы запускаете свой минихостинг для проекта и он сразу доступен.

Если у вас появится новый проект и поменяется окружение, достаточно скопировать чистую виртуалку (если вы на винде), скопировать папку BitrixDock, добавить или заменить сервисы и запустить.

P.S. Виртуальная машина от разработчиков Битрикс на Apache, а у нас на Nginx, а он работает намного быстрее и кушает меньше памяти.

Использование xdebug.

  • Настройки xdebug задаются в phpXX/php.ini.
  • По умолчанию порт xdebug на 9004 порту
  • При изменении php.ini в проекте не забудьте добавить флаг --build при запуске docker-compose, чтобы форсировать пересборку образа.

Пример

Пример реального Docker проекта для Bitrix - Single Node https://github.com/bitrixdock/production-single-node

Ещё один проект с php7 и отправкой почты, взят с боевого проекта, вырезаны пароли, сертификаты и тп https://github.com/bitrixdock/bitrixdock-production

Ещё один production проект с memcached композитом, php8.2, почтой и кроном в контейнере и развёрнутым Readme (англ.): https://github.com/paskal/bitrix.infra

Реальные проекты на основе этих проектов работают годами без проблем если их не трогать ) Alt text

About

BitrixDock - это готовое Docker окружение для Bitrix CMS 🎯

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dockerfile 68.1%
  • PHP 10.3%
  • Makefile 8.9%
  • HTML 8.7%
  • Shell 4.0%
0