compose.yaml.j2 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. services:
  2. {{ service_name }}:
  3. image: docker.io/library/traefik:v3.5.4
  4. {% if not swarm_enabled %}
  5. container_name: {{ container_name }}
  6. security_opt:
  7. - no-new-privileges:true
  8. {% endif %}
  9. hostname: {{ container_hostname }}
  10. ports:
  11. - "{{ ports_http }}:80"
  12. - "{{ ports_https }}:443"
  13. {% if dashboard_enabled %}
  14. - "{{ ports_dashboard }}:8080"
  15. {% endif %}
  16. volumes:
  17. - /var/run/docker.sock:/var/run/docker.sock:ro
  18. {% if not swarm_enabled %}
  19. - ./config/:/etc/traefik/:ro
  20. - ./certs/:/var/traefik/certs/:rw
  21. {% else %}
  22. {% if swarm_volume_mode == 'mount' %}
  23. - {{ swarm_volume_mount_path }}:/var/traefik/certs/:rw
  24. {% elif swarm_volume_mode == 'local' %}
  25. - traefik_certs:/var/traefik/certs/:rw
  26. {% elif swarm_volume_mode == 'nfs' %}
  27. - traefik_certs:/var/traefik/certs/:rw
  28. {% endif %}
  29. {% endif %}
  30. {% if traefik_tls_enabled and not swarm_enabled %}
  31. - ./.env.secret:/.env.secret:ro
  32. {% endif %}
  33. env_file:
  34. - ./.env
  35. {% if swarm_enabled %}
  36. configs:
  37. - source: traefik_config
  38. target: /etc/traefik/traefik.yaml
  39. - source: traefik_middlewares
  40. target: /etc/traefik/files/middlewares.yaml
  41. - source: traefik_routers
  42. target: /etc/traefik/files/routers.yaml
  43. - source: traefik_services
  44. target: /etc/traefik/files/services.yaml
  45. {% endif %}
  46. environment:
  47. - TZ={{ container_timezone }}
  48. {% if traefik_tls_enabled and traefik_tls_acme_provider == 'cloudflare' %}
  49. - CF_API_TOKEN_FILE=/.env.secret
  50. {% endif %}
  51. healthcheck:
  52. test: ["CMD", "traefik", "healthcheck", "--ping"]
  53. interval: 30s
  54. timeout: 5s
  55. retries: 3
  56. start_period: 10s
  57. networks:
  58. - {{ traefik_network }}
  59. {% if swarm_enabled %}
  60. {% if traefik_tls_enabled %}
  61. secrets:
  62. - source: {{ traefik_tls_acme_secret_name }}
  63. target: /.env.secret
  64. mode: 0400
  65. {% endif %}
  66. deploy:
  67. mode: {{ swarm_placement_mode }}
  68. {% if swarm_placement_mode == 'replicated' %}
  69. replicas: {{ swarm_replicas }}
  70. {% endif %}
  71. {% if swarm_placement_host %}
  72. placement:
  73. constraints:
  74. - node.hostname == {{ swarm_placement_host }}
  75. {% endif %}
  76. {% else %}
  77. restart: {{ restart_policy }}
  78. {% endif %}
  79. {% if swarm_enabled %}
  80. {% if swarm_volume_mode in ['local', 'nfs'] %}
  81. volumes:
  82. traefik_certs:
  83. {% if swarm_volume_mode == 'nfs' %}
  84. driver: local
  85. driver_opts:
  86. type: nfs
  87. o: addr={{ swarm_volume_nfs_server }},nfsvers=4,{{ swarm_volume_nfs_options }}
  88. device: ":{{ swarm_volume_nfs_path }}"
  89. {% endif %}
  90. {% endif %}
  91. configs:
  92. traefik_config:
  93. file: ./config/traefik.yaml
  94. traefik_middlewares:
  95. file: ./config/files/middlewares.yaml
  96. traefik_routers:
  97. file: ./config/files/routers.yaml
  98. traefik_services:
  99. file: ./config/files/services.yaml
  100. {% if traefik_tls_enabled %}
  101. secrets:
  102. {{ traefik_tls_acme_secret_name }}:
  103. file: ./.env.secret
  104. {% endif %}
  105. {% endif %}
  106. networks:
  107. {{ traefik_network }}:
  108. {% if traefik_network_external %}
  109. external: true
  110. {% else %}
  111. {% if swarm_enabled %}
  112. driver: overlay
  113. attachable: true
  114. {% else %}
  115. driver: bridge
  116. {% endif %}
  117. name: {{ traefik_network }}
  118. {% endif %}