compose.yaml.j2 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  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. {% if network_mode == '' or network_mode == 'bridge' or traefik_enabled %}
  21. ports:
  22. {% if not traefik_enabled %}
  23. - "{{ ports_http }}:80/tcp"
  24. - "{{ ports_https }}:443/tcp"
  25. {% if initial_setup %}
  26. - "{{ ports_initial }}:3000/tcp"
  27. {% endif %}
  28. {% endif %}
  29. - "{{ ports_https }}:443/udp"
  30. - "{{ ports_dns }}:53/tcp"
  31. - "{{ ports_dns }}:53/udp"
  32. - "{{ ports_tls }}:853/tcp"
  33. - "{{ ports_dnscrypt }}:5443/tcp"
  34. - "{{ ports_dnscrypt }}:5443/udp"
  35. {% endif %}
  36. {% endif %}
  37. volumes:
  38. {% if volume_mode == 'mount' %}
  39. - {{ volume_mount_path }}/work:/opt/adguardhome/work:rw
  40. - {{ volume_mount_path }}/conf:/opt/adguardhome/conf:rw
  41. {% else %}
  42. - {{ service_name }}_work:/opt/adguardhome/work
  43. - {{ service_name }}_conf:/opt/adguardhome/conf
  44. {% endif %}
  45. cap_add:
  46. - NET_ADMIN
  47. - NET_BIND_SERVICE
  48. - NET_RAW
  49. {% if traefik_enabled %}
  50. labels:
  51. - traefik.enable=true
  52. - traefik.docker.network={{ traefik_network }}
  53. - traefik.http.services.{{ service_name }}_web.loadBalancer.server.port=80
  54. - traefik.http.routers.{{ service_name }}_http.service={{ service_name }}_web
  55. - traefik.http.routers.{{ service_name }}_http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  56. - traefik.http.routers.{{ service_name }}_http.entrypoints=web
  57. {% if traefik_tls_enabled %}
  58. - traefik.http.routers.{{ service_name }}_https.service={{ service_name }}_web
  59. - traefik.http.routers.{{ service_name }}_https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  60. - traefik.http.routers.{{ service_name }}_https.entrypoints=websecure
  61. - traefik.http.routers.{{ service_name }}_https.tls=true
  62. - traefik.http.routers.{{ service_name }}_https.tls.certresolver={{ traefik_tls_certresolver }}
  63. {% endif %}
  64. {% if initial_setup %}
  65. - traefik.http.services.{{ service_name }}_setup.loadBalancer.server.port=3000
  66. - traefik.http.routers.{{ service_name }}_setup.service={{ service_name }}_setup
  67. - traefik.http.routers.{{ service_name }}_setup.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`) && PathPrefix(`/setup`)
  68. - traefik.http.routers.{{ service_name }}_setup.entrypoints=web
  69. - traefik.http.middlewares.{{ service_name }}_setup-strip.stripprefix.prefixes=/setup
  70. - traefik.http.routers.{{ service_name }}_setup.middlewares={{ service_name }}_setup-strip
  71. {% endif %}
  72. {% endif %}
  73. {#
  74. Network definitions (only when needed):
  75. - When network_mode is empty: no definition needed (uses Docker's default bridge)
  76. - When network_mode is 'bridge': define custom bridge network
  77. - When network_mode is 'macvlan': configure macvlan with static IP (for Compose mode)
  78. Note: In Swarm mode, macvlan networks must be created manually with config-only networks on each node
  79. - When swarm_enabled: use overlay network for multi-host communication
  80. - Traefik network: always external (managed by Traefik)
  81. #}
  82. {% if network_mode == 'bridge' or network_mode == 'macvlan' or traefik_enabled %}
  83. networks:
  84. {% if network_mode == 'bridge' or network_mode == 'macvlan'%}
  85. {{ network_name }}:
  86. {% if network_external %}
  87. external: true
  88. {% else %}
  89. {% if network_mode == 'macvlan' %}
  90. driver: macvlan
  91. driver_opts:
  92. parent: {{ network_macvlan_parent_interface }}
  93. ipam:
  94. config:
  95. - subnet: {{ network_macvlan_subnet }}
  96. gateway: {{ network_macvlan_gateway }}
  97. name: {{ network_name }}
  98. {% elif swarm_enabled %}
  99. driver: overlay
  100. attachable: true
  101. {% else %}
  102. driver: bridge
  103. {% endif %}
  104. {% endif %}
  105. {% endif %}
  106. {% if traefik_enabled %}
  107. {{ traefik_network }}:
  108. external: true
  109. {% endif %}
  110. {% endif %}
  111. {#
  112. Volume definitions:
  113. - When volume_mode is 'local' (default): use docker-managed local volumes
  114. - When volume_mode is 'nfs': configure NFS-backed volumes
  115. - When volume_mode is 'mount': no volume definition needed (bind mounts used directly)
  116. #}
  117. {% if volume_mode == 'local' %}
  118. volumes:
  119. {{ service_name }}_work:
  120. driver: local
  121. {{ service_name }}_conf:
  122. driver: local
  123. {% elif volume_mode == 'nfs' %}
  124. volumes:
  125. {{ service_name }}_work:
  126. driver: local
  127. driver_opts:
  128. type: nfs
  129. o: addr={{ volume_nfs_server }},nfsvers=4,{{ volume_nfs_options }}
  130. device: ":{{ volume_nfs_path }}/work"
  131. {{ service_name }}_conf:
  132. driver: local
  133. driver_opts:
  134. type: nfs
  135. o: addr={{ volume_nfs_server }},nfsvers=4,{{ volume_nfs_options }}
  136. device: ":{{ volume_nfs_path }}/conf"
  137. {% endif %}