compose.yaml.j2.bak3 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. services:
  2. {{ service_name }}:
  3. image: docker.io/semaphoreui/semaphore:v2.16.43
  4. {% if not swarm_enabled %}
  5. restart: {{ restart_policy }}
  6. container_name: {{ container_name }}
  7. {% endif %}
  8. hostname: {{ container_hostname }}
  9. user: "{{ user_uid }}:{{ user_gid }}"
  10. environment:
  11. - TZ={{ container_timezone }}
  12. {% if database_type == 'mysql' %}
  13. - SEMAPHORE_DB_DIALECT=mysql
  14. {% elif database_type == 'postgres' %}
  15. - SEMAPHORE_DB_DIALECT=postgres
  16. {% endif %}
  17. {% if database_external %}
  18. - SEMAPHORE_DB_HOST={{ database_host }}
  19. {% else %}
  20. - SEMAPHORE_DB_HOST={{ service_name }}-{{ database_type }}
  21. {% endif %}
  22. - SEMAPHORE_DB_PORT={% if database_type == 'postgres' %}5432{% else %}3306{% endif %}
  23. - SEMAPHORE_DB={{ database_name }}
  24. - SEMAPHORE_DB_USER={{ database_user }}
  25. - SEMAPHORE_DB_PASS=${DATABASE_PASSWORD}
  26. - SEMAPHORE_ADMIN={{ semaphore_admin_name }}
  27. - SEMAPHORE_ADMIN_NAME={{ semaphore_admin_name }}
  28. - SEMAPHORE_ADMIN_EMAIL={{ semaphore_admin_email }}
  29. - SEMAPHORE_ADMIN_PASSWORD=${SEMAPHORE_ADMIN_PASSWORD}
  30. - SEMAPHORE_PLAYBOOK_PATH={{ semaphore_playbook_path }}
  31. - SEMAPHORE_ACCESS_KEY_ENCRYPTION=${SEMAPHORE_ACCESS_KEY_ENCRYPTION}
  32. - ANSIBLE_HOST_KEY_CHECKING={{ ansible_host_key_checking }}
  33. {% if email_enabled %}
  34. - SEMAPHORE_EMAIL_SENDER={{ email_from }}
  35. - SEMAPHORE_EMAIL_HOST={{ email_host }}
  36. - SEMAPHORE_EMAIL_PORT={{ email_port }}
  37. - SEMAPHORE_EMAIL_USERNAME={{ email_username }}
  38. - SEMAPHORE_EMAIL_PASSWORD=${EMAIL_PASSWORD}
  39. - SEMAPHORE_EMAIL_SECURE={{ email_use_tls }}
  40. {% endif %}
  41. {% if network_mode == 'host' %}
  42. network_mode: host
  43. {% else %}
  44. networks:
  45. {% if traefik_enabled %}
  46. {{ traefik_network }}:
  47. {% endif %}
  48. {% if network_mode == 'macvlan' %}
  49. {{ network_name }}:
  50. ipv4_address: {{ network_macvlan_ipv4_address }}
  51. {% elif network_mode == 'bridge' %}
  52. {{ network_name }}:
  53. {% endif %}
  54. {% endif %}
  55. {% if not traefik_enabled and network_mode == 'bridge' %}
  56. ports:
  57. {% if swarm_enabled %}
  58. - target: 3000
  59. published: {{ ports_http }}
  60. protocol: tcp
  61. mode: host
  62. {% else %}
  63. - "{{ ports_http }}:3000"
  64. {% endif %}
  65. {% endif %}
  66. volumes:
  67. - ./inventory:/inventory:ro
  68. - ./authorized-keys:/authorized-keys:ro
  69. - ./config:/etc/semaphore:rw
  70. {% if traefik_enabled and not swarm_enabled %}
  71. labels:
  72. - traefik.enable=true
  73. - traefik.docker.network={{ traefik_network }}
  74. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=3000
  75. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  76. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  77. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  78. {% if traefik_tls_enabled %}
  79. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  80. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  81. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  82. - traefik.http.routers.{{ service_name }}-https.tls=true
  83. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  84. {% endif %}
  85. {% endif %}
  86. depends_on:
  87. {% if database_type == 'mysql' %}
  88. - {{ service_name }}-mysql
  89. {% elif database_type == 'postgres' %}
  90. - {{ service_name }}-postgres
  91. {% endif %}
  92. {% if swarm_enabled or resources_enabled %}
  93. deploy:
  94. {% if swarm_enabled %}
  95. mode: {{ swarm_placement_mode }}
  96. {% if swarm_placement_mode == 'replicated' %}
  97. replicas: {{ swarm_replicas }}
  98. {% endif %}
  99. {% if swarm_placement_host %}
  100. placement:
  101. constraints:
  102. - node.hostname == {{ swarm_placement_host }}
  103. {% endif %}
  104. restart_policy:
  105. condition: on-failure
  106. {% endif %}
  107. {% if resources_enabled %}
  108. resources:
  109. limits:
  110. cpus: '{{ resources_cpu_limit }}'
  111. memory: {{ resources_memory_limit }}
  112. {% if swarm_enabled %}
  113. reservations:
  114. cpus: '{{ resources_cpu_reservation }}'
  115. memory: {{ resources_memory_reservation }}
  116. {% endif %}
  117. {% endif %}
  118. {% if swarm_enabled and traefik_enabled %}
  119. labels:
  120. - traefik.enable=true
  121. - traefik.docker.network={{ traefik_network }}
  122. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=3000
  123. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  124. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  125. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  126. {% if authentik_enabled %}
  127. - traefik.http.routers.{{ service_name }}-http.middlewares={{ authentik_traefik_middleware }}
  128. {% endif %}
  129. {% if traefik_tls_enabled %}
  130. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  131. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  132. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  133. - traefik.http.routers.{{ service_name }}-https.tls=true
  134. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  135. {% if authentik_enabled %}
  136. - traefik.http.routers.{{ service_name }}-https.middlewares={{ authentik_traefik_middleware }}
  137. {% endif %}
  138. {% endif %}
  139. {% endif %}
  140. {% endif %}
  141. {% if not database_external %}
  142. {% if database_type == 'mysql' %}
  143. {{ service_name }}-mysql:
  144. image: docker.io/library/mysql:8.4
  145. {% if not swarm_enabled %}
  146. restart: {{ restart_policy }}
  147. container_name: {{ service_name }}-mysql
  148. {% endif %}
  149. environment:
  150. {% if database_type == 'mysql' %}
  151. - MYSQL_RANDOM_ROOT_PASSWORD=yes
  152. - MYSQL_DATABASE={{ database_name }}
  153. - MYSQL_USER={{ database_user }}
  154. - MYSQL_PASSWORD=${DATABASE_PASSWORD}
  155. - MYSQL_CHARSET=utf8mb4
  156. - MYSQL_COLLATION=utf8mb4_unicode_ci
  157. {% elif database_type == 'postgres' %}
  158. - POSTGRES_DB={{ database_name }}
  159. - POSTGRES_USER={{ database_user }}
  160. - POSTGRES_PASSWORD=${DATABASE_PASSWORD}
  161. - POSTGRES_INITDB_ARGS=--encoding=UTF8 --locale=C
  162. {% endif %}
  163. healthcheck:
  164. test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-u", "{{ database_user }}", "-p{{ database_password }}"]
  165. start_period: 30s
  166. interval: 10s
  167. timeout: 10s
  168. retries: 5
  169. {% if network_mode == 'host' %}
  170. network_mode: host
  171. {% else %}
  172. networks:
  173. {% if traefik_enabled %}
  174. {{ traefik_network }}:
  175. {% endif %}
  176. {% if network_mode == 'macvlan' %}
  177. {{ network_name }}:
  178. ipv4_address: {{ network_macvlan_ipv4_address }}
  179. {% elif network_mode == 'bridge' %}
  180. {{ network_name }}:
  181. {% endif %}
  182. {% endif %}
  183. volumes:
  184. - database_data:/var/lib/mysql
  185. {% elif database_type == 'postgres' %}
  186. {{ service_name }}-postgres:
  187. image: docker.io/library/postgres:17.6
  188. {% if not swarm_enabled %}
  189. restart: {{ restart_policy }}
  190. container_name: {{ service_name }}-postgres
  191. {% endif %}
  192. environment:
  193. {% if database_type == 'mysql' %}
  194. - MYSQL_RANDOM_ROOT_PASSWORD=yes
  195. - MYSQL_DATABASE={{ database_name }}
  196. - MYSQL_USER={{ database_user }}
  197. - MYSQL_PASSWORD=${DATABASE_PASSWORD}
  198. - MYSQL_CHARSET=utf8mb4
  199. - MYSQL_COLLATION=utf8mb4_unicode_ci
  200. {% elif database_type == 'postgres' %}
  201. - POSTGRES_DB={{ database_name }}
  202. - POSTGRES_USER={{ database_user }}
  203. - POSTGRES_PASSWORD=${DATABASE_PASSWORD}
  204. - POSTGRES_INITDB_ARGS=--encoding=UTF8 --locale=C
  205. {% endif %}
  206. healthcheck:
  207. test: ["CMD-SHELL", "pg_isready -U {{ database_user }}"]
  208. start_period: 30s
  209. interval: 10s
  210. timeout: 10s
  211. retries: 5
  212. {% if network_mode == 'host' %}
  213. network_mode: host
  214. {% else %}
  215. networks:
  216. {% if traefik_enabled %}
  217. {{ traefik_network }}:
  218. {% endif %}
  219. {% if network_mode == 'macvlan' %}
  220. {{ network_name }}:
  221. ipv4_address: {{ network_macvlan_ipv4_address }}
  222. {% elif network_mode == 'bridge' %}
  223. {{ network_name }}:
  224. {% endif %}
  225. {% endif %}
  226. volumes:
  227. - database_data:/var/lib/postgresql/data
  228. {% endif %}
  229. {% endif %}
  230. {% if network_mode != 'host' %}
  231. networks:
  232. {{ network_name }}:
  233. {% if network_external %}
  234. external: true
  235. {% else %}
  236. {% if network_mode == 'macvlan' %}
  237. driver: macvlan
  238. driver_opts:
  239. parent: {{ network_macvlan_parent_interface }}
  240. ipam:
  241. config:
  242. - subnet: {{ network_macvlan_subnet }}
  243. gateway: {{ network_macvlan_gateway }}
  244. name: {{ network_name }}
  245. {% elif swarm_enabled %}
  246. driver: overlay
  247. attachable: true
  248. {% else %}
  249. driver: bridge
  250. {% endif %}
  251. {% endif %}
  252. {% if traefik_enabled %}
  253. {{ traefik_network }}:
  254. external: true
  255. {% endif %}
  256. {% endif %}
  257. volumes:
  258. {% if not database_external %}
  259. database_data:
  260. driver: local
  261. {% endif %}