netbox-docker/docker-compose.yml

135 lines
3.4 KiB
YAML
Raw Normal View History

services:
netbox: &netbox
2025-04-12 08:26:09 +00:00
image: docker.io/netboxcommunity/netbox:${VERSION-v4.3-3.3.0}
depends_on:
2025-04-09 14:23:09 +00:00
#- postgres
2024-09-03 18:22:55 +00:00
- redis
- redis-cache
env_file: env/netbox.env
2024-09-03 18:22:55 +00:00
user: "unit:root"
deploy:
resources:
limits:
memory: "4g"
cpus: "5"
labels:
- traefik.enable=true
- traefik.http.routers.netbox.rule=Host(`netbox.dfestaging.jennyme.co.za`)
- traefik.http.routers.netbox.tls.certresolver=myresolver # Use the ACME resolver
- traefik.http.routers.netbox.entrypoints=websecure # Use the HTTPS entrypoint
- traefik.http.services.netbox.loadbalancer.server.port=8000
healthcheck:
2024-05-25 13:45:25 +00:00
test: curl -f http://localhost:8080/login/ || exit 1
2024-05-10 08:19:55 +00:00
start_period: 90s
timeout: 3s
interval: 15s
volumes:
2024-09-03 18:22:55 +00:00
- ./configuration:/etc/netbox/config:z,ro
- netbox-media-files:/opt/netbox/netbox/media:rw
- netbox-reports-files:/opt/netbox/netbox/reports:rw
- netbox-scripts-files:/opt/netbox/netbox/scripts:rw
networks:
- netbox
- dfe_network
netbox-worker:
<<: *netbox
depends_on:
netbox:
condition: service_healthy
command:
2024-09-03 18:22:55 +00:00
- /opt/netbox/venv/bin/python
- /opt/netbox/netbox/manage.py
- rqworker
healthcheck:
2024-04-19 19:14:21 +00:00
test: ps -aux | grep -v grep | grep -q rqworker || exit 1
start_period: 20s
timeout: 3s
interval: 15s
networks:
- netbox
- dfe_network
netbox-housekeeping:
<<: *netbox
depends_on:
netbox:
condition: service_healthy
command:
2024-09-03 18:22:55 +00:00
- /opt/netbox/housekeeping.sh
healthcheck:
2024-04-19 19:14:21 +00:00
test: ps -aux | grep -v grep | grep -q housekeeping || exit 1
start_period: 20s
timeout: 3s
interval: 15s
networks:
- netbox
- dfe_network
# postgres
2025-04-09 14:23:09 +00:00
#postgres:
# image: docker.io/postgres:17-alpine
# healthcheck:
# test: pg_isready -q -t 2 -d $$POSTGRES_DB -U $$POSTGRES_USER
# start_period: 20s
# timeout: 30s
# interval: 10s
# retries: 5
# env_file: env/postgres.env
# volumes:
# - netbox-postgres-data:/var/lib/postgresql/data
# redis
redis:
image: docker.io/valkey/valkey:8.1-alpine
command:
2024-09-03 18:22:55 +00:00
- sh
- -c # this is to evaluate the $REDIS_PASSWORD from the env
- valkey-server --appendonly yes --requirepass $$REDIS_PASSWORD ## $$ because of docker-compose
2024-04-19 19:14:21 +00:00
healthcheck: &redis-healthcheck
2024-09-03 18:22:55 +00:00
test: '[ $$(valkey-cli --pass "$${REDIS_PASSWORD}" ping) = ''PONG'' ]'
2024-04-19 19:14:21 +00:00
start_period: 5s
2024-04-19 15:11:06 +00:00
timeout: 3s
2024-04-19 19:14:21 +00:00
interval: 1s
2024-04-19 15:11:06 +00:00
retries: 5
2020-10-26 14:16:49 +00:00
env_file: env/redis.env
volumes:
2024-09-03 18:22:55 +00:00
- netbox-redis-data:/data
networks:
- netbox
- dfe_network
2019-12-16 11:51:59 +00:00
redis-cache:
image: docker.io/valkey/valkey:8.1-alpine
2019-12-16 11:51:59 +00:00
command:
2024-09-03 18:22:55 +00:00
- sh
- -c # this is to evaluate the $REDIS_PASSWORD from the env
- valkey-server --requirepass $$REDIS_PASSWORD ## $$ because of docker-compose
2024-04-19 19:14:21 +00:00
healthcheck: *redis-healthcheck
env_file: env/redis-cache.env
volumes:
2024-09-03 18:22:55 +00:00
- netbox-redis-cache-data:/data
networks:
- netbox
- dfe_network
volumes:
netbox-media-files:
driver: local
netbox-postgres-data:
driver: local
netbox-redis-cache-data:
driver: local
netbox-redis-data:
driver: local
netbox-reports-files:
driver: local
netbox-scripts-files:
driver: local
networks:
netbox:
driver: "overlay"
#driver: bridge
attachable: true
dfe_network:
external: true