2019-12-23 10:53:19 -06:00
|
|
|
version: '3.4'
|
|
|
|
services:
|
2023-03-16 15:44:08 -05:00
|
|
|
netbox: &netbox
|
2019-12-23 10:53:19 -06:00
|
|
|
image: ${IMAGE-netboxcommunity/netbox:latest}
|
|
|
|
depends_on:
|
2022-11-30 02:52:07 -06:00
|
|
|
postgres:
|
|
|
|
condition: service_healthy
|
|
|
|
redis:
|
|
|
|
condition: service_started
|
|
|
|
redis-cache:
|
|
|
|
condition: service_started
|
2019-12-23 10:53:19 -06:00
|
|
|
env_file: env/netbox.env
|
2021-09-24 01:16:07 -05:00
|
|
|
user: 'unit:root'
|
2019-12-23 10:53:19 -06:00
|
|
|
volumes:
|
2022-08-31 07:05:34 -05:00
|
|
|
- ./test-configuration/logging.py:/etc/netbox/config/logging.py:z,ro
|
2023-03-16 15:44:08 -05:00
|
|
|
healthcheck:
|
|
|
|
start_period: 120s
|
|
|
|
timeout: 3s
|
|
|
|
interval: 15s
|
|
|
|
test: "curl -f http://localhost:8080/api/ || exit 1"
|
|
|
|
netbox-worker:
|
|
|
|
<<: *netbox
|
|
|
|
command:
|
|
|
|
- /opt/netbox/venv/bin/python
|
|
|
|
- /opt/netbox/netbox/manage.py
|
|
|
|
- rqworker
|
|
|
|
healthcheck:
|
|
|
|
start_period: 40s
|
|
|
|
timeout: 3s
|
|
|
|
interval: 15s
|
|
|
|
test: "ps -aux | grep -v grep | grep -q rqworker || exit 1"
|
|
|
|
netbox-housekeeping:
|
|
|
|
<<: *netbox
|
|
|
|
command:
|
|
|
|
- /opt/netbox/housekeeping.sh
|
|
|
|
healthcheck:
|
|
|
|
start_period: 40s
|
|
|
|
timeout: 3s
|
|
|
|
interval: 15s
|
|
|
|
test: "ps -aux | grep -v grep | grep -q housekeeping || exit 1"
|
2019-12-23 10:53:19 -06:00
|
|
|
postgres:
|
2022-11-11 08:24:44 -06:00
|
|
|
image: postgres:15-alpine
|
2019-12-23 10:53:19 -06:00
|
|
|
env_file: env/postgres.env
|
2022-11-30 02:52:07 -06:00
|
|
|
healthcheck:
|
|
|
|
test: ["CMD-SHELL", "pg_isready"]
|
|
|
|
interval: 10s
|
|
|
|
timeout: 5s
|
|
|
|
retries: 5
|
2019-12-23 10:53:19 -06:00
|
|
|
redis:
|
2022-06-09 01:12:46 -05:00
|
|
|
image: redis:7-alpine
|
2019-12-23 10:53:19 -06:00
|
|
|
command:
|
|
|
|
- sh
|
|
|
|
- -c # this is to evaluate the $REDIS_PASSWORD from the env
|
2020-02-14 05:35:47 -06:00
|
|
|
- redis-server --appendonly yes --requirepass $$REDIS_PASSWORD ## $$ because of docker-compose
|
2019-12-23 10:53:19 -06:00
|
|
|
env_file: env/redis.env
|
2020-02-14 05:35:47 -06:00
|
|
|
redis-cache:
|
2022-06-09 01:12:46 -05:00
|
|
|
image: redis:7-alpine
|
2020-02-14 05:35:47 -06:00
|
|
|
command:
|
|
|
|
- sh
|
|
|
|
- -c # this is to evaluate the $REDIS_PASSWORD from the env
|
|
|
|
- redis-server --requirepass $$REDIS_PASSWORD ## $$ because of docker-compose
|
|
|
|
env_file: env/redis-cache.env
|
2019-12-23 10:53:19 -06:00
|
|
|
volumes:
|
|
|
|
netbox-media-files:
|
|
|
|
driver: local
|