The image contains the apache web server and the librebooking application files. It needs to be linked to a MariaDB database container.
Environment variables are used on first invocation of the container (when the file config/config.php does not yet exist)
Env | Default | Example | Required | config.php settings |
---|---|---|---|---|
LB_DB_HOST |
- | lb-db | Yes | ['settings']['database']['hostspec'] |
LB_DB_NAME |
- | librebooking | Yes | ['settings']['database']['name'] |
LB_DB_USER |
- | lb_user | Yes | ['settings']['database']['user'] |
LB_DB_USER_PWD |
- | myPassw0rd | Yes | ['settings']['database']['password'] |
LB_INSTALL_PWD |
- | installPWD | Yes | ['settings']['install.password'] |
TZ |
- | Europe/Zurich | Yes | ['settings']['default.timezone'] |
LB_LOG_FOLDER |
/var/log/librebooking | No | ['settings']['logging']['folder'] | |
LB_LOG_LEVEL |
none | debug | No | ['settings']['logging']['level'] |
LB_LOG_SQL |
false | true | No | ['settings']['logging']['sql'] |
LB_ENV |
production | dev | No | N/A - Used to initialize file config.php |
LB_PATH |
- | book | No | N/A - URL path prefix (usually none) |
This simple setup is meant for testing the application within your private network.
Run the following commands:
# Create the container network
docker network create mynet
# Run the database
docker run \
--name librebooking-db \
--detach \
--network mynet \
--volume librebooking-db:/config \
--env PUID=1000 \
--env PGID=1000 \
--env TZ=Europe/Zurich \
--env MYSQL_ROOT_PASSWORD=your_Mariadb_root_password \
linuxserver/mariadb:10.6.13
# Run librebooking
docker run \
--name librebooking \
--detach \
--network mynet \
--publish 80:80 \
--volume librebooking-conf:/config \
--env LB_DB_NAME=librebooking \
--env LB_DB_USER=lb_user \
--env LB_DB_USER_PWD=your_Mariadb_user_password \
--env LB_DB_HOST=librebooking-db \
--env LB_INSTALL_PWD=your_Librebooking_installation_password \
--env LB_ENV=dev \
--env LB_LOG_FOLDER=/var/log/librebooking \
--env LB_LOG_LEVEL=debug \
--env LB_LOG_SQL=false \
--env TZ=Europe/Zurich \
librebooking/librebooking:develop
This simple setup is meant for testing the application within your private network.
Create a docker-compose.yml
file from the following sample and adapt the
value of the environment variables to your needs:
version: "3.7"
services:
db:
image: linuxserver/mariadb:10.6.13
restart: always
networks:
- mynet
volumes:
- db_conf:/config
environment:
- PUID=1000
- PGID=1000
- TZ=Europe/Zurich
- MYSQL_ROOT_PASSWORD=your_Mariadb_root_password
app:
image: librebooking/librebooking:develop
restart: always
depends_on:
- db
networks:
- mynet
ports:
- "80:80"
volumes:
- app_conf:/config
environment:
- LB_DB_NAME=librebooking
- LB_DB_USER=lb_user
- LB_DB_USER_PWD=your_Mariadb_user_password
- LB_DB_HOST=db
- LB_INSTALL_PWD=your_Librebooking_installation_password
- LB_ENV=dev
- LB_LOG_FOLDER=/var/log/librebooking
- LB_LOG_LEVEL=debug
- LB_LOG_SQL=false
- TZ=Europe/Zurich
volumes:
db_conf:
app_conf:
networks:
mynet:
Start the application with the following command:
docker-compose up --detach
This setup is meant for accessing the application from the internet. It features:
- A reverse proxy based on nginx that automatically handle certificates
- The usage of secrets to pass passwords to the docker container
- A librebooking service accessible without a URL-path (ex: https://librebooking.your-domain.com)
- A librebooking service accessible with a URL-path (ex: https://your-domain.com/book)
Create a docker-compose.yml
file from the following sample and adapt the value of the environment variables to your needs:
version: "3.7"
services:
proxy:
image: nginxproxy/nginx-proxy
restart: always
networks:
- mynet
ports:
- 80:80
- 443:443
volumes:
- proxy_certs:/etc/nginx/certs
- proxy_html:/usr/share/nginx/html
- /var/run/docker.sock:/tmp/docker.sock:ro
acme:
image: nginxproxy/acme-companion
restart: always
depends_on:
- proxy
networks:
- mynet
volumes_from:
- proxy
volumes:
- acme_acme:/etc/acme.sh
- /var/run/docker.sock:/var/run/docker.sock:ro
environment:
- [email protected]
db:
image: linuxserver/mariadb:10.6.13
restart: always
networks:
- mynet
volumes:
- db_conf:/config
environment:
- PUID=1000
- PGID=1000
- TZ=Europe/Zurich
- FILE__MYSQL_ROOT_PASSWORD=/run/secrets/db_root_pwd
secrets:
- db_root_pwd
- db_user_pwd
lb1:
image: librebooking/librebooking:2.8.6.2
restart: always
depends_on:
- db
networks:
- mynet
volumes:
- lb1_conf:/config
environment:
- LB_DB_NAME=lb1
- LB_INSTALL_PWD_FILE=/run/secrets/lb_install_pwd
- LB_DB_USER=lb1
- LB_DB_USER_PWD_FILE=/run/secrets/lb_user_pwd
- LB_DB_HOST=db
- LB_ENV=production
- LB_LOG_FOLDER=/var/log/librebooking
- LB_LOG_LEVEL=error
- LB_LOG_SQL=false
- LB_PATH=lb1
- TZ=Europe/Zurich
- VIRTUAL_HOST=your_host_com
- VIRTUAL_PATH=/your_path
- LETSENCRYPT_HOST=your_host_com
secrets:
- lb_install_pwd
- lb_user_pwd
lb2:
image: librebooking/librebooking:2.8.6.2
restart: always
depends_on:
- db
networks:
- mynet
volumes:
- lb2_conf:/config
environment:
- LB_DB_NAME=lb2
- LB_INSTALL_PWD_FILE=/run/secrets/lb_install_pwd
- LB_DB_USER=lb2
- LB_DB_USER_PWD_FILE=/run/secrets/lb_user_pwd
- LB_DB_HOST=db
- LB_ENV=production
- LB_LOG_FOLDER=/var/log/librebooking
- LB_LOG_LEVEL=error
- LB_LOG_SQL=false
- TZ=Europe/Zurich
- VIRTUAL_HOST=your_host_com
- LETSENCRYPT_HOST=your_host_com
secrets:
- lb_install_pwd
- lb_user_pwd
volumes:
proxy_certs:
proxy_html:
acme_acme:
db_conf:
lb1_conf:
lb2_conf:
networks:
mynet:
secrets:
db_root_pwd:
file: ./pwd_db_root.txt
db_user_pwd:
file: ./pwd_db_user.txt
lb_user_pwd:
file: ./pwd_db_user.txt
lb_install_pwd:
file: ./pwd_lb_inst.txt
Set the secrets with the following commands:
echo -n 'your_Mariadb_root_password' > pwd_db_root.txt;
echo -n 'your_Mariadb_user_password' > pwd_db_user.txt;
echo -n 'your_Librebooking_installation_password' > pwd_lb_inst.txt;
Start the application with the following command:
docker-compose up --detach