compose.yaml.j2 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. services:
  2. {{ service_name }}:
  3. image: docker.io/library/traefik:v3.5.3
  4. {% if not swarm_enabled %}
  5. container_name: {{ container_name }}
  6. {% endif %}
  7. {% if ports_enabled %}
  8. ports:
  9. - "80:80"
  10. - "443:443"
  11. {% if traefik_dashboard_enabled %}
  12. - "8080:8080" # Dashboard (don't use in production)
  13. {% endif %}
  14. {% endif %}
  15. volumes:
  16. - /var/run/docker.sock:/var/run/docker.sock:ro
  17. {% if not swarm_enabled %}
  18. - ./config/:/etc/traefik/:ro
  19. - ./certs/:/var/traefik/certs/:rw
  20. {% else %}
  21. {% if swarm_volume_mode == 'mount' %}
  22. - {{ swarm_volume_mount_path }}:/var/traefik/certs/:rw
  23. {% elif swarm_volume_mode == 'local' %}
  24. - traefik_certs:/var/traefik/certs/:rw
  25. {% elif swarm_volume_mode == 'nfs' %}
  26. - traefik_certs:/var/traefik/certs/:rw
  27. {% endif %}
  28. {% endif %}
  29. {% if traefik_tls_enabled %}
  30. {% if not swarm_enabled %}
  31. - ./.env.secret:/.env.secret:ro
  32. {% endif %}
  33. env_file:
  34. - ./.env
  35. {% endif %}
  36. {% if swarm_enabled %}
  37. configs:
  38. - source: traefik_config
  39. target: /etc/traefik/traefik.yaml
  40. - source: traefik_middlewares
  41. target: /etc/traefik/files/middlewares.yaml
  42. - source: traefik_tls
  43. target: /etc/traefik/files/tls.yaml
  44. - source: traefik_external_services
  45. target: /etc/traefik/files/external-services.yaml
  46. {% endif %}
  47. environment:
  48. - TZ={{ container_timezone }}
  49. healthcheck:
  50. test: ["CMD", "traefik", "healthcheck", "--ping"]
  51. interval: 30s
  52. timeout: 5s
  53. retries: 3
  54. start_period: 10s
  55. {% if network_enabled %}
  56. networks:
  57. - {{ network_name }}
  58. {% endif %}
  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 }},{{ 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_tls:
  97. file: ./config/files/tls.yaml
  98. traefik_external_services:
  99. file: ./config/files/external-services.yaml
  100. {% if traefik_tls_enabled %}
  101. secrets:
  102. {{ traefik_tls_acme_secret_name }}:
  103. file: ./.env.secret
  104. {% endif %}
  105. {% endif %}
  106. {% if network_enabled %}
  107. networks:
  108. {{ network_name }}:
  109. {% if network_external %}
  110. external: true
  111. {% else %}
  112. {% if swarm_enabled %}
  113. driver: overlay
  114. attachable: true
  115. {% else %}
  116. driver: bridge
  117. {% endif %}
  118. name: {{ network_name }}
  119. {% endif %}
  120. {% endif %}