compose.yaml.j2 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. ---
  2. services:
  3. {{ service_name }}:
  4. image: docker.io/adguard/adguardhome:v0.107.69
  5. restart: {{ restart_policy }}
  6. {% if network_mode == 'host' %}
  7. network_mode: host
  8. {% elif network_mode == 'bridge' or network_mode == 'macvlan' or traefik_enabled %}
  9. networks:
  10. {% if traefik_enabled %}
  11. {{ traefik_network }}:
  12. {% endif %}
  13. {% if network_mode == 'macvlan' %}
  14. {{ network_name }}:
  15. ipv4_address: {{ network_macvlan_ipv4_address }}
  16. {% elif network_mode == 'bridge' %}
  17. {{ network_name }}:
  18. {% endif %}
  19. {% endif %}
  20. {#
  21. Port mappings (only in bridge mode or default network):
  22. - HTTP/HTTPS (80/443) ports are only exposed when Traefik is disabled
  23. - Initial setup port 3000 is exposed during first-time setup
  24. - DNS and related ports (53, 853, 5443) are always exposed
  25. - In host or macvlan mode, ports are bound directly to host network
  26. #}
  27. {% if network_mode == '' or network_mode == 'bridge' or traefik_enabled %}
  28. ports:
  29. {% if not traefik_enabled %}
  30. - "{{ ports_http }}:80/tcp"
  31. - "{{ ports_https }}:443/tcp"
  32. {% if initial_setup %}
  33. - "{{ ports_initial }}:3000/tcp"
  34. {% endif %}
  35. {% endif %}
  36. - "{{ ports_https }}:443/udp"
  37. - "{{ ports_dns }}:53/tcp"
  38. - "{{ ports_dns }}:53/udp"
  39. - "{{ ports_tls }}:853/tcp"
  40. - "{{ ports_dnscrypt }}:5443/tcp"
  41. - "{{ ports_dnscrypt }}:5443/udp"
  42. {% endif %}
  43. volumes:
  44. {% if volume_mode == 'mount' %}
  45. - {{ volume_mount_path }}/work:/opt/adguardhome/work:rw
  46. - {{ volume_mount_path }}/conf:/opt/adguardhome/conf:rw
  47. {% else %}
  48. - {{ service_name }}_work:/opt/adguardhome/work
  49. - {{ service_name }}_conf:/opt/adguardhome/conf
  50. {% endif %}
  51. cap_add:
  52. - NET_ADMIN
  53. - NET_BIND_SERVICE
  54. - NET_RAW
  55. {% if traefik_enabled %}
  56. labels:
  57. - traefik.enable=true
  58. - traefik.docker.network={{ traefik_network }}
  59. - traefik.http.services.{{ service_name }}_web.loadBalancer.server.port=80
  60. - traefik.http.routers.{{ service_name }}_http.service={{ service_name }}_web
  61. - traefik.http.routers.{{ service_name }}_http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  62. - traefik.http.routers.{{ service_name }}_http.entrypoints=web
  63. {% if traefik_tls_enabled %}
  64. - traefik.http.routers.{{ service_name }}_https.service={{ service_name }}_web
  65. - traefik.http.routers.{{ service_name }}_https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  66. - traefik.http.routers.{{ service_name }}_https.entrypoints=websecure
  67. - traefik.http.routers.{{ service_name }}_https.tls=true
  68. - traefik.http.routers.{{ service_name }}_https.tls.certresolver={{ traefik_tls_certresolver }}
  69. {% endif %}
  70. {#
  71. Initial setup routing (port 3000):
  72. Routes setup wizard through separate Traefik service.
  73. Note: Setup wizard is available at http://<host>.<domain>/setup during initial configuration.
  74. #}
  75. {% if initial_setup %}
  76. - traefik.http.services.{{ service_name }}_setup.loadBalancer.server.port=3000
  77. - traefik.http.routers.{{ service_name }}_setup.service={{ service_name }}_setup
  78. - traefik.http.routers.{{ service_name }}_setup.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`) && PathPrefix(`/setup`)
  79. - traefik.http.routers.{{ service_name }}_setup.entrypoints=web
  80. - traefik.http.middlewares.{{ service_name }}_setup-strip.stripprefix.prefixes=/setup
  81. - traefik.http.routers.{{ service_name }}_setup.middlewares={{ service_name }}_setup-strip
  82. {% endif %}
  83. {% endif %}
  84. {% if network_mode == 'bridge' or network_mode == 'macvlan' or traefik_enabled %}
  85. {#
  86. Network definitions:
  87. - 'bridge' mode: creates custom bridge network
  88. - 'macvlan' mode: creates macvlan network with static IP assignment
  89. (requires manual network creation in Swarm mode)
  90. - Swarm overlay: used when swarm_enabled=true with bridge mode
  91. - Traefik network: always external (managed separately by Traefik stack)
  92. - Default mode (network_mode=''): uses Docker's default bridge (no definition needed)
  93. - Host mode: no network definition (container uses host network stack directly)
  94. #}
  95. networks:
  96. {% if network_mode == 'bridge' or network_mode == 'macvlan'%}
  97. {{ network_name }}:
  98. {% if network_external %}
  99. external: true
  100. {% else %}
  101. {% if network_mode == 'macvlan' %}
  102. driver: macvlan
  103. driver_opts:
  104. parent: {{ network_macvlan_parent_interface }}
  105. ipam:
  106. config:
  107. - subnet: {{ network_macvlan_subnet }}
  108. gateway: {{ network_macvlan_gateway }}
  109. name: {{ network_name }}
  110. {% elif swarm_enabled %}
  111. driver: overlay
  112. attachable: true
  113. {% else %}
  114. driver: bridge
  115. {% endif %}
  116. {% endif %}
  117. {% endif %}
  118. {% if traefik_enabled %}
  119. {{ traefik_network }}:
  120. external: true
  121. {% endif %}
  122. {% endif %}
  123. {% if volume_mode == 'local' %}
  124. {#
  125. Volume definitions:
  126. - 'local' mode: Docker-managed local volumes
  127. - 'nfs' mode: NFS-backed volumes for shared storage
  128. - 'mount' mode: bind mounts (no volume definition needed)
  129. #}
  130. volumes:
  131. {{ service_name }}_work:
  132. driver: local
  133. {{ service_name }}_conf:
  134. driver: local
  135. {% elif volume_mode == 'nfs' %}
  136. volumes:
  137. {{ service_name }}_work:
  138. driver: local
  139. driver_opts:
  140. type: nfs
  141. o: addr={{ volume_nfs_server }},nfsvers=4,{{ volume_nfs_options }}
  142. device: ":{{ volume_nfs_path }}/work"
  143. {{ service_name }}_conf:
  144. driver: local
  145. driver_opts:
  146. type: nfs
  147. o: addr={{ volume_nfs_server }},nfsvers=4,{{ volume_nfs_options }}
  148. device: ":{{ volume_nfs_path }}/conf"
  149. {% endif %}