compose.yaml.j2 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. services:
  2. {{ service_name }}:
  3. image: docker.io/library/nginx:1.28.2-alpine
  4. {#
  5. If not in swarm mode, apply restart policy and container name
  6. #}
  7. {% if not swarm_enabled %}
  8. restart: {{ restart_policy }}
  9. container_name: {{ container_name }}
  10. {% endif %}
  11. {#
  12. When traefik is enabled, add traefik network for reverse proxy access
  13. #}
  14. {% if traefik_enabled %}
  15. networks:
  16. {{ traefik_network }}:
  17. {% endif %}
  18. {#
  19. Port mappings for HTTP and HTTPS (only when Traefik is disabled)
  20. Note: Swarm mode uses 'host' mode for port publishing to avoid port conflicts
  21. #}
  22. {% if not traefik_enabled %}
  23. ports:
  24. {% if swarm_enabled %}
  25. - target: 80
  26. published: {{ ports_http }}
  27. protocol: tcp
  28. mode: host
  29. - target: 443
  30. published: {{ ports_https }}
  31. protocol: tcp
  32. mode: host
  33. {% else %}
  34. - "{{ ports_http }}:80"
  35. - "{{ ports_https }}:443"
  36. {% endif %}
  37. {% endif %}
  38. {#
  39. Volume configuration (commented out - uncomment and customize as needed):
  40. - config: Nginx configuration files
  41. - data: Static content to serve
  42. #}
  43. # volumes:
  44. # - ./config/default.conf:/etc/nginx/conf.d/default.conf:ro
  45. # - ./data:/usr/share/nginx/html:ro
  46. {#
  47. When traefik_enabled is set, and not running in swarm mode, add traefik labels
  48. (optionally enable TLS if traefik_tls_enabled is set)
  49. #}
  50. {% if traefik_enabled and not swarm_enabled %}
  51. labels:
  52. - traefik.enable=true
  53. - traefik.docker.network={{ traefik_network }}
  54. - traefik.http.services.{{ service_name }}-web.loadbalancer.server.port=80
  55. - traefik.http.routers.{{ service_name }}-web-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  56. - traefik.http.routers.{{ service_name }}-web-http.entrypoints={{ traefik_entrypoint }}
  57. - traefik.http.routers.{{ service_name }}-web-http.service={{ service_name }}-web
  58. {% if traefik_tls_enabled %}
  59. - traefik.http.routers.{{ service_name }}-web-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  60. - traefik.http.routers.{{ service_name }}-web-https.entrypoints={{ traefik_tls_entrypoint }}
  61. - traefik.http.routers.{{ service_name }}-web-https.tls=true
  62. - traefik.http.routers.{{ service_name }}-web-https.tls.certresolver={{ traefik_tls_certresolver }}
  63. - traefik.http.routers.{{ service_name }}-web-https.service={{ service_name }}-web
  64. {% endif %}
  65. {% endif %}
  66. {#
  67. Deploy configuration for Swarm mode:
  68. - Configure replicas
  69. - Traefik: Labels for reverse proxy integration (Swarm mode)
  70. #}
  71. {% if swarm_enabled %}
  72. deploy:
  73. replicas: {{ swarm_replicas }}
  74. {#
  75. When traefik_enabled is set in swarm mode, add traefik labels
  76. (optionally enable TLS if traefik_tls_enabled is set)
  77. #}
  78. {% if traefik_enabled %}
  79. labels:
  80. - traefik.enable=true
  81. - traefik.docker.network={{ traefik_network }}
  82. - traefik.http.services.{{ service_name }}-web.loadbalancer.server.port=80
  83. - traefik.http.routers.{{ service_name }}-web-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  84. - traefik.http.routers.{{ service_name }}-web-http.entrypoints={{ traefik_entrypoint }}
  85. - traefik.http.routers.{{ service_name }}-web-http.service={{ service_name }}-web
  86. {% if traefik_tls_enabled %}
  87. - traefik.http.routers.{{ service_name }}-web-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  88. - traefik.http.routers.{{ service_name }}-web-https.entrypoints={{ traefik_tls_entrypoint }}
  89. - traefik.http.routers.{{ service_name }}-web-https.tls=true
  90. - traefik.http.routers.{{ service_name }}-web-https.tls.certresolver={{ traefik_tls_certresolver }}
  91. - traefik.http.routers.{{ service_name }}-web-https.service={{ service_name }}-web
  92. {% endif %}
  93. {% endif %}
  94. {% endif %}
  95. {#
  96. Network definitions (only when Traefik is enabled):
  97. - Traefik network: always external (managed by Traefik)
  98. #}
  99. {% if traefik_enabled %}
  100. networks:
  101. {{ traefik_network }}:
  102. external: true
  103. {% endif %}