compose.yaml.j2 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. ---
  2. services:
  3. {{ service_name }}:
  4. image: docker.io/pihole/pihole:2025.11.0
  5. {% if not swarm_enabled %}
  6. restart: {{ restart_policy }}
  7. container_name: {{ container_name }}
  8. {% endif %}
  9. hostname: {{ container_hostname }}
  10. environment:
  11. - TZ={{ container_timezone }}
  12. - PIHOLE_UID={{ user_uid }}
  13. - PIHOLE_GID={{ user_gid }}
  14. {% if swarm_enabled %}
  15. - WEBPASSWORD_FILE={{ service_name }}_webpassword
  16. {% else %}
  17. - FTLCONF_webserver_api_password=${WEBPASSWORD}
  18. {% endif %}
  19. {% if network_mode == 'bridge' %}
  20. - FTLCONF_dns_listeningMode=all
  21. {% endif %}
  22. {% if network_mode == 'host' %}
  23. network_mode: host
  24. {% else %}
  25. networks:
  26. {% if traefik_enabled %}
  27. {{ traefik_network }}:
  28. {% endif %}
  29. {% if network_mode == 'macvlan' %}
  30. {{ network_name }}:
  31. ipv4_address: {{ network_macvlan_ipv4_address }}
  32. {% elif network_mode == 'bridge' %}
  33. {{ network_name }}:
  34. {% endif %}
  35. {% endif %}
  36. {% if not traefik_enabled and network_mode == 'bridge' %}
  37. ports:
  38. {% if not traefik_enabled %}
  39. {% if swarm_enabled %}
  40. - target: 80
  41. published: {{ ports_http }}
  42. protocol: tcp
  43. mode: host
  44. - target: 443
  45. published: {{ ports_https }}
  46. protocol: tcp
  47. mode: host
  48. {% else %}
  49. - "{{ ports_http }}:80/tcp"
  50. - "{{ ports_https }}:443/tcp"
  51. {% endif %}
  52. {% endif %}
  53. {% if swarm_enabled %}
  54. - target: 53
  55. published: {{ ports_dns }}
  56. protocol: tcp
  57. mode: host
  58. - target: 53
  59. published: {{ ports_dns }}
  60. protocol: udp
  61. mode: host
  62. - target: 123
  63. published: {{ ports_ntp }}
  64. protocol: udp
  65. mode: host
  66. {% else %}
  67. - "{{ ports_dns }}:53/tcp"
  68. - "{{ ports_dns }}:53/udp"
  69. - "{{ ports_ntp }}:123/udp"
  70. {% endif %}
  71. {% endif %}
  72. volumes:
  73. {% if volume_mode == 'mount' %}
  74. - {{ volume_mount_path }}/dnsmasq:/etc/dnsmasq.d:rw
  75. - {{ volume_mount_path }}/pihole:/etc/pihole:rw
  76. {% elif volume_mode in ['local', 'nfs'] %}
  77. - {{ service_name }}-dnsmasq:/etc/dnsmasq.d
  78. - {{ service_name }}-pihole:/etc/pihole
  79. {% endif %}
  80. cap_add:
  81. - NET_ADMIN
  82. - SYS_TIME
  83. {% if swarm_enabled %}
  84. secrets:
  85. - {{ service_name }}_webpassword
  86. {% endif %}
  87. {% if swarm_enabled or resources_enabled %}
  88. deploy:
  89. {% if swarm_enabled %}
  90. mode: replicated
  91. replicas: 1
  92. placement:
  93. constraints:
  94. - node.hostname == {{ swarm_placement_host }}
  95. restart_policy:
  96. condition: on-failure
  97. {% endif %}
  98. {% if resources_enabled %}
  99. resources:
  100. limits:
  101. cpus: '{{ resources_cpu_limit }}'
  102. memory: {{ resources_memory_limit }}
  103. {% if swarm_enabled %}
  104. reservations:
  105. cpus: '{{ resources_cpu_reservation }}'
  106. memory: {{ resources_memory_reservation }}
  107. {% endif %}
  108. {% endif %}
  109. {% if swarm_enabled and traefik_enabled %}
  110. labels:
  111. - traefik.enable=true
  112. - traefik.docker.network={{ traefik_network }}
  113. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=80
  114. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  115. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}`)
  116. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  117. {% if traefik_tls_enabled %}
  118. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  119. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}`)
  120. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  121. - traefik.http.routers.{{ service_name }}-https.tls=true
  122. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  123. {% endif %}
  124. {% endif %}
  125. {% endif %}
  126. {% if traefik_enabled and not swarm_enabled %}
  127. labels:
  128. - traefik.enable=true
  129. - traefik.docker.network={{ traefik_network }}
  130. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=80
  131. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  132. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}`)
  133. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  134. {% if traefik_tls_enabled %}
  135. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  136. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}`)
  137. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  138. - traefik.http.routers.{{ service_name }}-https.tls=true
  139. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  140. {% endif %}
  141. {% endif %}
  142. {% if swarm_enabled %}
  143. secrets:
  144. {{ service_name }}_webpassword:
  145. file: ./.env.secret.webpassword
  146. {% endif %}
  147. {% if volume_mode == 'local' %}
  148. volumes:
  149. {{ service_name }}-dnsmasq:
  150. driver: local
  151. {{ service_name }}-pihole:
  152. driver: local
  153. {% elif volume_mode == 'nfs' %}
  154. volumes:
  155. {{ service_name }}-dnsmasq:
  156. driver: local
  157. driver_opts:
  158. type: nfs
  159. o: addr={{ volume_nfs_server }},{{ volume_nfs_options }}
  160. device: ":{{ volume_nfs_path }}/dnsmasq"
  161. {{ service_name }}-pihole:
  162. driver: local
  163. driver_opts:
  164. type: nfs
  165. o: addr={{ volume_nfs_server }},{{ volume_nfs_options }}
  166. device: ":{{ volume_nfs_path }}/pihole"
  167. {% endif %}
  168. {% if network_mode != 'host' %}
  169. networks:
  170. {{ network_name }}:
  171. {% if network_external %}
  172. external: true
  173. {% else %}
  174. {% if network_mode == 'macvlan' %}
  175. driver: macvlan
  176. driver_opts:
  177. parent: {{ network_macvlan_parent_interface }}
  178. ipam:
  179. config:
  180. - subnet: {{ network_macvlan_subnet }}
  181. gateway: {{ network_macvlan_gateway }}
  182. name: {{ network_name }}
  183. {% elif swarm_enabled %}
  184. driver: overlay
  185. attachable: true
  186. {% else %}
  187. driver: bridge
  188. {% endif %}
  189. {% endif %}
  190. {% if traefik_enabled %}
  191. {{ traefik_network }}:
  192. external: true
  193. {% endif %}
  194. {% endif %}