BitrixDock позволяет легко и просто запускать Bitrix CMS на Docker.
BitrixDock запускает демо Битрикса предоставляя готовые сервисы PHP, NGINX, MySQL и многие другие.
- Сервис PHP запакован в отдельный образ, чтобы избавить разработчиков от долгого компилирования.
- Остальные сервисы так же "причёсаны" и разворачиваются моментально.
- Ничего лишнего.
- Git
- Docker
- Docker Compose v2
Если вы работаете в Windows, то все заводится на штатном WSL2 + Docker Desktop
Как альтернативный вариант - можно поднять виртуальную машину (через Vagrant, VirtualBox, VMware и тп).
Ваш рабочий проект должен хранится в двух местах, первое — локальная папка с проектами на хосте (открывается в IDE), второе — виртуальная машина
(например /var/www/bitrix). Проект на хосте мапится в IDE к гостевой OC.
Для разворачивания на Linux или macOS:
curl -fsSL https://raw.githubusercontent.com/bitrixdock/bitrixdock/master/install.sh?$(date +%s) -o install.sh && chmod +x install.sh && sh install.shМожно указать путь установки (по умолчанию текущая директория):
sh install.sh ~/projectsСкопируйте файл .env_template в .env
cp -f .env_template .env⚠ Если у вас мак, удалите строчку /etc/localtime:/etc/localtime/:ro из docker-compose.yml
По умолчанию используется nginx, php 8.2, mysql. Настройки можно изменить в файле .env. Также можно задать путь к каталогу с сайтом и параметры базы данных MySQL.
COMPOSE_PROJECT_NAME=bitrixdock # Имя проекта. Используется для наименования контейнеров
PHP_VERSION=php82 # Версия php
PHP_WORKSPACE_VERSION=8.2 # Версия PHP для workspace контейнера
NODE_VERSION=24.12.0 # Версия Node.js для workspace контейнера
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 # На данный интерфейс будут проксироваться порты
SITE_PATH=./www # Путь к директории Вашего сайтаЕсли у вас всё получилось, будем благодарны за звёздочку :) Ошибки ждём в issue Приятной работы!
docker compose -p bitrixdock up -dЧтобы проверить, что все сервисы запустились посмотрите список процессов docker ps.
Посмотрите все прослушиваемые порты, должны быть 80, 11211, 9000 netstat -plnt.
Откройте IP машины в браузере.
В bitrixdock есть профили для запуска опциональных сервисов:
admin- для запуска сервиса Adminer (веб-интерфейс для управления базами данных)push- для запуска push-сервера Битрикс и Redisworkspace- для запуска workspace контейнера с инструментами разработки
Для запуска с профилями:
docker compose -p bitrixdock --profile admin --profile push up -dДля запуска с workspace:
docker compose -p bitrixdock --profile workspace up -ddocker compose -p bitrixdock stopdocker compose -p bitrixdock downWorkspace — это готовый к работе контейнер с инструментами для разработки и отладки
Запустите контейнер с профилем workspace:
docker compose -p bitrixdock --profile workspace up -dПодключитесь к контейнеру:
docker compose exec -u www-data workspace bash
# или используйте команду из Makefile
make console-workspaceВнутри контейнера доступны:
php- PHP CLI с нужными расширениямиcomposer- менеджер пакетов PHPnode,npm,yarn,pnpm- для работы с JavaScriptbitrix- CLI инструмент Битриксgit- для работы с репозиторием
- По умолчанию стоит папка
./www(папка внутри репозиториия) - В настройках подключения требуется указывать имя docker compose сервиса, например для подключения к базе нужно указывать "db", а не "localhost". Пример конфига с подключением к mysql и memcached.
- Для загрузки резервной копии в контейнер используйте команду:
cat /var/www/bitrix/backup.sql | docker exec -i mysql /usr/bin/mysql -u root -p123 bitrix - При использовании в production удалите строку с xdebug из соответствующего
phpXX/Dockerfile, сам факт его установки снижает производительность Битрикса и он должен использоваться только для разработки - Если контейнер 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 задаются в
phpXX/php.ini. - Для php73, php74 дефолтовые настройки xdebug - коннект на порт
9003хоста, с которого пришел запрос. В случае невозможности коннекта - фаллбек наhost.docker.internal. - При изменении
php.iniв проекте не забудьте добавить флаг--buildпри запускеdocker-compose, чтобы форсировать пересборку образа.
Помогите развитию проекта! Требуется закрывать задачи в issue
Пример реального 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
Реальные проекты на основе этих проектов работают годами без проблем если их не трогать )
- Форкаем оригинальный проект https://github.com/bitrixdock/bitrixdock кнопкой Fork
- Клонируем форк себе на компьютер
git clone https://github.com/my_account/bitrixdock
cd bitrixdock- Создаем новую ветку
git checkout -b myfix- Создаем upstream на оригинальный проект
git remote add upstream https://github.com/bitrixdock/bitrixdock- Меняем файлы
- Делаем коммит и отправляем правки
git add .
git commit -am "My fixes"
git push -u origin new_branch- Переходим в свой проект
https://github.com/my_account/bitrixdockи жмем кнопку Compare & pull request - Описываем какую проблему решает Пул Реквест с кратким описанием, зачем сделано изменение
- Вы прекрасны! ;)