| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- ---
- services:
- {{ service_name }}:
- image: docker.io/adguard/adguardhome:v0.107.69
- restart: {{ restart_policy }}
- {% if network_mode == 'host' %}
- network_mode: host
- {% elif network_mode == 'bridge' or network_mode == 'macvlan' or traefik_enabled %}
- networks:
- {% if traefik_enabled %}
- {{ traefik_network }}:
- {% endif %}
- {% if network_mode == 'macvlan' %}
- {{ network_name }}:
- ipv4_address: {{ network_macvlan_ipv4_address }}
- {% elif network_mode == 'bridge' %}
- {{ network_name }}:
- {% endif %}
- {% endif %}
- {#
- Port mappings (only in bridge mode or default network):
- - HTTP/HTTPS (80/443) ports are only exposed when Traefik is disabled
- - Initial setup port 3000 is exposed during first-time setup
- - DNS and related ports (53, 853, 5443) are always exposed
- - In host or macvlan mode, ports are bound directly to host network
- #}
- {% if network_mode == '' or network_mode == 'bridge' or traefik_enabled %}
- ports:
- {% if not traefik_enabled %}
- - "{{ ports_http }}:80/tcp"
- - "{{ ports_https }}:443/tcp"
- {% if initial_setup %}
- - "{{ ports_initial }}:3000/tcp"
- {% endif %}
- {% endif %}
- - "{{ ports_https }}:443/udp"
- - "{{ ports_dns }}:53/tcp"
- - "{{ ports_dns }}:53/udp"
- - "{{ ports_tls }}:853/tcp"
- - "{{ ports_dnscrypt }}:5443/tcp"
- - "{{ ports_dnscrypt }}:5443/udp"
- {% endif %}
- volumes:
- {% if volume_mode == 'mount' %}
- - {{ volume_mount_path }}/work:/opt/adguardhome/work:rw
- - {{ volume_mount_path }}/conf:/opt/adguardhome/conf:rw
- {% else %}
- - {{ service_name }}_work:/opt/adguardhome/work
- - {{ service_name }}_conf:/opt/adguardhome/conf
- {% endif %}
- cap_add:
- - NET_ADMIN
- - NET_BIND_SERVICE
- - NET_RAW
- {% if traefik_enabled %}
- labels:
- - traefik.enable=true
- - traefik.docker.network={{ traefik_network }}
- - traefik.http.services.{{ service_name }}_web.loadBalancer.server.port=80
- - traefik.http.routers.{{ service_name }}_http.service={{ service_name }}_web
- - traefik.http.routers.{{ service_name }}_http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
- - traefik.http.routers.{{ service_name }}_http.entrypoints=web
- {% if traefik_tls_enabled %}
- - traefik.http.routers.{{ service_name }}_https.service={{ service_name }}_web
- - traefik.http.routers.{{ service_name }}_https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
- - traefik.http.routers.{{ service_name }}_https.entrypoints=websecure
- - traefik.http.routers.{{ service_name }}_https.tls=true
- - traefik.http.routers.{{ service_name }}_https.tls.certresolver={{ traefik_tls_certresolver }}
- {% endif %}
- {#
- Initial setup routing (port 3000):
- Routes setup wizard through separate Traefik service.
- Note: Setup wizard is available at http://<host>.<domain>/setup during initial configuration.
- #}
- {% if initial_setup %}
- - traefik.http.services.{{ service_name }}_setup.loadBalancer.server.port=3000
- - traefik.http.routers.{{ service_name }}_setup.service={{ service_name }}_setup
- - traefik.http.routers.{{ service_name }}_setup.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`) && PathPrefix(`/setup`)
- - traefik.http.routers.{{ service_name }}_setup.entrypoints=web
- - traefik.http.middlewares.{{ service_name }}_setup-strip.stripprefix.prefixes=/setup
- - traefik.http.routers.{{ service_name }}_setup.middlewares={{ service_name }}_setup-strip
- {% endif %}
- {% endif %}
- {% if network_mode == 'bridge' or network_mode == 'macvlan' or traefik_enabled %}
- {#
- Network definitions:
- - 'bridge' mode: creates custom bridge network
- - 'macvlan' mode: creates macvlan network with static IP assignment
- (requires manual network creation in Swarm mode)
- - Swarm overlay: used when swarm_enabled=true with bridge mode
- - Traefik network: always external (managed separately by Traefik stack)
- - Default mode (network_mode=''): uses Docker's default bridge (no definition needed)
- - Host mode: no network definition (container uses host network stack directly)
- #}
- networks:
- {% if network_mode == 'bridge' or network_mode == 'macvlan'%}
- {{ network_name }}:
- {% if network_external %}
- external: true
- {% else %}
- {% if network_mode == 'macvlan' %}
- driver: macvlan
- driver_opts:
- parent: {{ network_macvlan_parent_interface }}
- ipam:
- config:
- - subnet: {{ network_macvlan_subnet }}
- gateway: {{ network_macvlan_gateway }}
- name: {{ network_name }}
- {% elif swarm_enabled %}
- driver: overlay
- attachable: true
- {% else %}
- driver: bridge
- {% endif %}
- {% endif %}
- {% endif %}
- {% if traefik_enabled %}
- {{ traefik_network }}:
- external: true
- {% endif %}
- {% endif %}
- {% if volume_mode == 'local' %}
- {#
- Volume definitions:
- - 'local' mode: Docker-managed local volumes
- - 'nfs' mode: NFS-backed volumes for shared storage
- - 'mount' mode: bind mounts (no volume definition needed)
- #}
- volumes:
- {{ service_name }}_work:
- driver: local
- {{ service_name }}_conf:
- driver: local
- {% elif volume_mode == 'nfs' %}
- volumes:
- {{ service_name }}_work:
- driver: local
- driver_opts:
- type: nfs
- o: addr={{ volume_nfs_server }},nfsvers=4,{{ volume_nfs_options }}
- device: ":{{ volume_nfs_path }}/work"
- {{ service_name }}_conf:
- driver: local
- driver_opts:
- type: nfs
- o: addr={{ volume_nfs_server }},nfsvers=4,{{ volume_nfs_options }}
- device: ":{{ volume_nfs_path }}/conf"
- {% endif %}
|