BitrixDock позволяет легко и просто запускать Bitrix CMS на Docker.
BitrixDock запускает демо Битрикса предоставляя готовые сервисы PHP, NGINX, MySQL и многие другие.
- Сервис PHP запакован в отдельный образ, чтобы избавить разработчиков от долгого компилирования.
- Остальные сервисы так же "причёсаны" и разворачиваются моментально.
- Ничего лишнего.
Если вы работаете в Windows, то все заводится на штатном WSL2 + Docker Desktop
Как альтернативный вариант - можно поднять виртуальную машину (через Vagrant, VirtualBox, VMware и тп), тестировалось на Ubuntu 18.04.
Ваш рабочий проект должен хранится в двух местах, первое — локальная папка с проектами на хосте (открывается в IDE), второе — виртуальная машина
(например /var/www/bitrix
). Проект на хосте мапится в IDE к гостевой OC.
curl -fsSL https://raw.githubusercontent.com/jackkiwema/bitrixdock/master/install.wsl.sh?$(date +%s) -o install.wsl.sh && chmod +x install.wsl.sh && sh install.wsl.sh
curl -fsSL https://raw.githubusercontent.com/jackkiwema/bitrixdock/master/install.sh -o install.sh && chmod +x install.sh && sh install.sh
Читать
- Git
apt-get update && apt-get install -y git
- Docker & Docker-Compose
cd /usr/local/src && wget -qO- https://get.docker.com/ | sh && \
curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose && \
chmod +x /usr/local/bin/docker-compose && \
echo "alias dc='docker-compose'" >> ~/.bash_aliases && \
source ~/.bashrc
mkdir -p /var/www/bitrix && \
cd /var/www/bitrix && \
wget https://www.1c-bitrix.ru/download/scripts/bitrixsetup.php && \
cd /var/www/ && \
git clone https://github.com/bitrixdock/bitrixdock.git && \
cd /var/ && chmod -R 775 www/ && chown -R root:www-data www/ && \
cd /var/www/bitrixdock
Скопируйте файл .env_template
в .env
cp -f .env_template .env
⚠ Если у вас мак, удалите строчку /etc/localtime:/etc/localtime/:ro
из docker-compose.yml
По умолчанию используется nginx, php 7.4, mysql. Настройки можно изменить в файле .env
. Также можно задать путь к каталогу с сайтом и параметры базы данных MySQL.
COMPOSE_PROJECT_NAME=bitrixdock # Project Name. Used to name containers
PHP_VERSION=php74 # php Version
WEB_SERVER_TYPE=nginx # Web Server nginx/apache
DB_SERVER_TYPE=mysql # Database Server mysql/percona
MYSQL_DATABASE=bitrix # Database Name
MYSQL_USER=bitrix # Database User
MYSQL_PASSWORD=123 # Password for accessing the Database
MYSQL_ROOT_PASSWORD=123 # Database Root user password
INTERFACE=0.0.0.0 # Ports will be proxied to this interface
SITE_PATH=/var/www/bitrix # Path to site directory
Если у вас всё получилось, будем благодарны за звёздочку :) Ошибки ждём в issue Приятной работы!
docker compose -p bitrixdock up -d
Чтобы проверить, что все сервисы запустились посмотрите список процессов docker ps
.
Посмотрите все прослушиваемые порты, должны быть 80, 11211, 9000 netstat -plnt
.
Откройте IP машины в браузере.
docker compose -p bitrixdock stop
docker compose -p bitrixdock down
- По умолчанию стоит папка
/var/www/bitrix/
- В настройках подключения требуется указывать имя сервиса, например для подключения к базе нужно указывать "db", а не "localhost". Пример конфига с подключением к mysql и memcached.
- Для загрузки резервной копии в контейнер используйте команду:
cat /var/www/bitrix/backup.sql | docker exec -i mysql /usr/bin/mysql -u root -p123 bitrix
- При использовании php74 в production удалите строку с
php7.4-xdebug
из файлаphp74/Dockerfile
, сам факт его установки снижает производительность Битрикса и он должен использоваться только для разработки
Виртуальная машина от разработчиков Битрикс решает ту же задачу, что и 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 - Описываем какую проблему решает Пул Реквест с кратким описанием, зачем сделано изменение
- Вы прекрасны! ;)
# Docker and Docker Compose Install
sudo su -
curl -fsSL https://get.docker.com -o docker.sh
bash ./docker.sh
curl -L "https://github.com/docker/compose/releases/download/v2.20.3/docker-compose-linux-x86_64" -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
echo "alias dc='docker-compose'" >> ~/.bash_aliases
source ~/.bashrc
# Bitrix Files Download
mkdir -p /var/www/bitrix
cd /var/www/bitrix
wget https://www.1c-bitrix.ru/download/scripts/bitrixsetup.php
cd /var/www/
git clone https://github.com/bitrixdock/bitrixdock.git
cd /var/ && chmod -R 775 www/ && chown -R root:www-data www/
cd /var/www/bitrixdock
# Environment Setup
cp -f .env_template .env
# Starting and Stopping Bitrixdock
docker compose -p bitrixdock up -d
# Install Bitrix
# DB Configuration
db name: db
User: bitrix
password: 123
db: bitrix