compose.yaml.j2 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. services:
  2. {{ service_name | default('nginx') }}:
  3. image: docker.io/library/nginx:1.28.0-alpine
  4. {% if not swarm_enabled %}
  5. container_name: {{ container_name | default('nginx') }}
  6. {% endif %}
  7. {% if swarm_enabled %}
  8. deploy:
  9. replicas: {{ swarm_replicas | default(1) }}
  10. {% if traefik_enabled %}
  11. labels:
  12. - traefik.enable=true
  13. - traefik.http.services.{{ container_name | default('nginx') }}.loadbalancer.server.port=80
  14. - traefik.http.routers.{{ container_name | default('nginx') }}-http.rule=Host(`{{ traefik_host }}`)
  15. - traefik.http.routers.{{ container_name | default('nginx') }}-http.entrypoints={{ traefik_entrypoint | default('web') }}
  16. - traefik.http.routers.{{ container_name | default('nginx') }}-http.service={{ container_name | default('nginx') }}
  17. {% if traefik_tls_enabled %}
  18. - traefik.http.routers.{{ container_name | default('nginx') }}-https.rule=Host(`{{ traefik_host }}`)
  19. - traefik.http.routers.{{ container_name | default('nginx') }}-https.entrypoints={{ traefik_tls_entrypoint | default('websecure') }}
  20. - traefik.http.routers.{{ container_name | default('nginx') }}-https.tls=true
  21. - traefik.http.routers.{{ container_name | default('nginx') }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  22. - traefik.http.routers.{{ container_name | default('nginx') }}-https.service={{ container_name | default('nginx') }}
  23. {% endif %}
  24. {% endif %}
  25. {% endif %}
  26. {% if ports_enabled %}
  27. ports:
  28. - "{{ ports_http | default(8080) }}:80"
  29. - "{{ ports_https | default(8443) }}:443"
  30. {% endif %}
  31. # volumes:
  32. # - ./config/default.conf:/etc/nginx/conf.d/default.conf:ro
  33. # - ./data:/usr/share/nginx/html:ro
  34. {% if traefik_enabled and not swarm_enabled %}
  35. labels:
  36. - traefik.enable=true
  37. - traefik.http.services.{{ container_name | default('nginx') }}.loadbalancer.server.port=80
  38. - traefik.http.routers.{{ container_name | default('nginx') }}-http.rule=Host(`{{ traefik_host }}`)
  39. - traefik.http.routers.{{ container_name | default('nginx') }}-http.entrypoints={{ traefik_entrypoint | default('web') }}
  40. - traefik.http.routers.{{ container_name | default('nginx') }}-http.service={{ container_name | default('nginx') }}
  41. {% if traefik_tls_enabled %}
  42. - traefik.http.routers.{{ container_name | default('nginx') }}-https.rule=Host(`{{ traefik_host }}`)
  43. - traefik.http.routers.{{ container_name | default('nginx') }}-https.entrypoints={{ traefik_tls_entrypoint | default('websecure') }}
  44. - traefik.http.routers.{{ container_name | default('nginx') }}-https.tls=true
  45. - traefik.http.routers.{{ container_name | default('nginx') }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  46. - traefik.http.routers.{{ container_name | default('nginx') }}-https.service={{ container_name | default('nginx') }}
  47. {% endif %}
  48. {% endif %}
  49. {% if network_enabled %}
  50. networks:
  51. - {{ network_name | default('bridge') }}
  52. {% endif %}
  53. {% if not swarm_enabled %}
  54. restart: {{ restart_policy | default('unless-stopped') }}
  55. {% endif %}
  56. {% if network_enabled %}
  57. networks:
  58. {{ network_name | default('bridge') }}:
  59. {% if network_external %}
  60. external: true
  61. {% endif %}
  62. {% endif %}