compose.yaml.j2 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. ---
  2. services:
  3. {{ service_name }}:
  4. image: docker.io/fosrl/pangolin:latest
  5. {% if not swarm_enabled %}
  6. restart: {{ restart_policy }}
  7. container_name: {{ container_name }}
  8. {% endif %}
  9. hostname: {{ container_hostname }}
  10. {% if network_mode == 'host' %}
  11. network_mode: host
  12. {% else %}
  13. networks:
  14. {% if traefik_enabled %}
  15. {{ traefik_network }}:
  16. {% endif %}
  17. {% if network_mode == 'macvlan' %}
  18. {{ network_name }}:
  19. ipv4_address: {{ network_macvlan_ipv4_address }}
  20. {% elif network_mode == 'bridge' %}
  21. {{ network_name }}:
  22. {% endif %}
  23. {% endif %}
  24. {% if network_mode == 'bridge' and not traefik_enabled %}
  25. ports:
  26. {% if swarm_enabled %}
  27. - target: 8080
  28. published: {{ ports_http }}
  29. protocol: tcp
  30. mode: host
  31. {% else %}
  32. - "{{ ports_http }}:8080/tcp"
  33. {% endif %}
  34. {% endif %}
  35. {% if environment_enabled or postgres_enabled %}
  36. environment:
  37. {% if postgres_enabled %}
  38. POSTGRES_CONNECTION_STRING: "{{ postgres_connection_string }}"
  39. {% endif %}
  40. {% if environment_enabled %}
  41. {% if environment_log_level %}
  42. LOG_LEVEL: "{{ environment_log_level }}"
  43. {% endif %}
  44. {% if environment_crowdsec_enabled %}
  45. CROWDSEC_ENABLED: "true"
  46. {% endif %}
  47. {% endif %}
  48. {% endif %}
  49. volumes:
  50. {% if volume_mode == 'mount' %}
  51. - {{ volume_mount_path }}/data:/app/data:rw
  52. - {{ volume_mount_path }}/config:/app/config:rw
  53. {% elif volume_mode in ['local', 'nfs'] %}
  54. - {{ service_name }}-data:/app/data
  55. - {{ service_name }}-config:/app/config
  56. {% endif %}
  57. {% if swarm_enabled or resources_enabled %}
  58. deploy:
  59. {% if swarm_enabled %}
  60. mode: replicated
  61. replicas: 1
  62. restart_policy:
  63. condition: on-failure
  64. {% endif %}
  65. {% if resources_enabled %}
  66. resources:
  67. limits:
  68. cpus: '{{ resources_cpu_limit }}'
  69. memory: {{ resources_memory_limit }}
  70. {% if swarm_enabled %}
  71. reservations:
  72. cpus: '{{ resources_cpu_reservation }}'
  73. memory: {{ resources_memory_reservation }}
  74. {% endif %}
  75. {% endif %}
  76. {% if swarm_enabled and traefik_enabled %}
  77. labels:
  78. - traefik.enable=true
  79. - traefik.docker.network={{ traefik_network }}
  80. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=8080
  81. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  82. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  83. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  84. {% if traefik_tls_enabled %}
  85. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  86. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  87. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  88. - traefik.http.routers.{{ service_name }}-https.tls=true
  89. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  90. {% endif %}
  91. {% endif %}
  92. {% endif %}
  93. {% if traefik_enabled and not swarm_enabled %}
  94. labels:
  95. - traefik.enable=true
  96. - traefik.docker.network={{ traefik_network }}
  97. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=8080
  98. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  99. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  100. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  101. {% if traefik_tls_enabled %}
  102. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  103. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  104. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  105. - traefik.http.routers.{{ service_name }}-https.tls=true
  106. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  107. {% endif %}
  108. {% endif %}
  109. {% if volume_mode == 'local' %}
  110. volumes:
  111. {{ service_name }}-data:
  112. driver: local
  113. {{ service_name }}-config:
  114. driver: local
  115. {% elif volume_mode == 'nfs' %}
  116. volumes:
  117. {{ service_name }}-data:
  118. driver: local
  119. driver_opts:
  120. type: nfs
  121. o: addr={{ volume_nfs_server }},{{ volume_nfs_options }}
  122. device: ":{{ volume_nfs_path }}/data"
  123. {{ service_name }}-config:
  124. driver: local
  125. driver_opts:
  126. type: nfs
  127. o: addr={{ volume_nfs_server }},{{ volume_nfs_options }}
  128. device: ":{{ volume_nfs_path }}/config"
  129. {% endif %}
  130. {% if network_mode != 'host' %}
  131. networks:
  132. {{ network_name }}:
  133. {% if network_external %}
  134. external: true
  135. {% else %}
  136. {% if network_mode == 'macvlan' %}
  137. driver: macvlan
  138. driver_opts:
  139. parent: {{ network_macvlan_parent_interface }}
  140. ipam:
  141. config:
  142. - subnet: {{ network_macvlan_subnet }}
  143. gateway: {{ network_macvlan_gateway }}
  144. name: {{ network_name }}
  145. {% elif swarm_enabled %}
  146. driver: overlay
  147. attachable: true
  148. {% else %}
  149. driver: bridge
  150. {% endif %}
  151. {% endif %}
  152. {% if traefik_enabled %}
  153. {{ traefik_network }}:
  154. external: true
  155. {% endif %}
  156. {% endif %}