64 lines
2 KiB
Docker
64 lines
2 KiB
Docker
# DOMAIN=example.com docker stack deploy -c odoo.yml odoo
|
|
# odoo --stop-after-init --no-xmlrpc --no-http -c /etc/odoo/odoo.conf --db_host db --database odoo --db_user odoo --db_password myp@ssw0rd -u all # Upgrade
|
|
# proxy_mode = True
|
|
|
|
services:
|
|
web:
|
|
image: odoo:${VERSION:-17.0}
|
|
entrypoint: /bin/sh
|
|
user: root
|
|
command:
|
|
- -c
|
|
- |
|
|
if [ ! -f /etc/odoo/odoo.conf ]; then
|
|
curl -o /etc/odoo/odoo.conf https://raw.githubusercontent.com/odoo/docker/master/$${VERSION:-17.0}/odoo.conf
|
|
fi
|
|
chown -R 101:101 /etc/odoo /var/lib/odoo
|
|
/entrypoint.sh odoo
|
|
volumes:
|
|
- ${VOLUME_PATH}odoo:/var/lib/odoo
|
|
- ${VOLUME_PATH}config:/etc/odoo
|
|
- ${VOLUME_PATH}addons:/mnt/extra-addons
|
|
environment:
|
|
- USER=odoo
|
|
- PASSWORD=myp@ssw0rd
|
|
deploy:
|
|
labels:
|
|
- traefik.enable=true
|
|
- traefik.http.routers.odoo-${NUMBER:-1}.rule=Host(`${DOMAIN:-odoo.localhost}`)
|
|
- traefik.http.routers.odoo-${NUMBER:-1}.entrypoints=${SCHEME:-https}
|
|
- traefik.http.routers.odoo-${NUMBER:-1}.service=odoo-${NUMBER:-1}
|
|
- traefik.http.routers.odoo-${NUMBER:-1}.tls.certresolver=letsencrypt
|
|
- traefik.http.routers.odoo-${NUMBER:-1}.middlewares=odoo-${NUMBER:-1}
|
|
- traefik.http.services.odoo-${NUMBER:-1}.loadbalancer.server.port=8069
|
|
- traefik.http.middlewares.odoo-${NUMBER:-1}.headers.customRequestHeaders.X-Forwarded-Proto=${SCHEME:-https}
|
|
networks:
|
|
- internal
|
|
- traefik
|
|
|
|
db:
|
|
image: postgres:${POSTGRES_VERSION:-12-alpine}
|
|
environment:
|
|
- POSTGRES_USER=odoo
|
|
- POSTGRES_DB=postgres
|
|
- POSTGRES_PASSWORD=myp@ssw0rd
|
|
healthcheck:
|
|
test: ["CMD", "pg_isready", "-U", "odoo"]
|
|
volumes:
|
|
- ${VOLUME_PATH}db:/var/lib/postgresql/data
|
|
networks:
|
|
- internal
|
|
|
|
volumes:
|
|
db:
|
|
odoo:
|
|
config:
|
|
addons:
|
|
|
|
networks:
|
|
internal:
|
|
driver: overlay
|
|
attachable: true
|
|
traefik:
|
|
external: true
|
|
name: traefik-net
|