compose.yaml.j2.portfix 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  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. {% endif %}
  42. {% if not traefik_enabled and network_mode == 'bridge' %}
  43. ports:
  44. {% if swarm_enabled %}
  45. - target: 3000
  46. published: {{ ports_http }}
  47. protocol: tcp
  48. mode: host
  49. {% else %}
  50. - "{{ ports_http }}:3000"
  51. {% endif %}
  52. {% endif %}
  53. volumes:
  54. - ./inventory:/inventory:ro
  55. - ./authorized-keys:/authorized-keys:ro
  56. - ./config:/etc/semaphore:rw
  57. {% if traefik_enabled and not swarm_enabled %}
  58. labels:
  59. - traefik.enable=true
  60. - traefik.docker.network={{ traefik_network }}
  61. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=3000
  62. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  63. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  64. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  65. {% if traefik_tls_enabled %}
  66. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  67. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  68. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  69. - traefik.http.routers.{{ service_name }}-https.tls=true
  70. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  71. {% endif %}
  72. {% endif %}
  73. depends_on:
  74. {% if database_type == 'mysql' %}
  75. - {{ service_name }}-mysql
  76. {% elif database_type == 'postgres' %}
  77. - {{ service_name }}-postgres
  78. {% endif %}
  79. {% if swarm_enabled or resources_enabled %}
  80. deploy:
  81. {% if swarm_enabled %}
  82. mode: {{ swarm_placement_mode }}
  83. {% if swarm_placement_mode == 'replicated' %}
  84. replicas: {{ swarm_replicas }}
  85. {% endif %}
  86. {% if swarm_placement_host %}
  87. placement:
  88. constraints:
  89. - node.hostname == {{ swarm_placement_host }}
  90. {% endif %}
  91. restart_policy:
  92. condition: on-failure
  93. {% endif %}
  94. {% if resources_enabled %}
  95. resources:
  96. limits:
  97. cpus: '{{ resources_cpu_limit }}'
  98. memory: {{ resources_memory_limit }}
  99. {% if swarm_enabled %}
  100. reservations:
  101. cpus: '{{ resources_cpu_reservation }}'
  102. memory: {{ resources_memory_reservation }}
  103. {% endif %}
  104. {% endif %}
  105. {% if swarm_enabled and traefik_enabled %}
  106. labels:
  107. - traefik.enable=true
  108. - traefik.docker.network={{ traefik_network }}
  109. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=3000
  110. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  111. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  112. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  113. {% if authentik_enabled %}
  114. - traefik.http.routers.{{ service_name }}-http.middlewares={{ authentik_traefik_middleware }}
  115. {% endif %}
  116. {% if traefik_tls_enabled %}
  117. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  118. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  119. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  120. - traefik.http.routers.{{ service_name }}-https.tls=true
  121. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  122. {% if authentik_enabled %}
  123. - traefik.http.routers.{{ service_name }}-https.middlewares={{ authentik_traefik_middleware }}
  124. {% endif %}
  125. {% endif %}
  126. {% endif %}
  127. {% endif %}
  128. {% if not database_external %}
  129. {% if database_type == 'mysql' %}
  130. {{ service_name }}-mysql:
  131. image: docker.io/library/mysql:8.4
  132. {% if not swarm_enabled %}
  133. restart: {{ restart_policy }}
  134. container_name: {{ service_name }}-mysql
  135. {% endif %}
  136. environment:
  137. {% if database_type == 'mysql' %}
  138. - MYSQL_RANDOM_ROOT_PASSWORD=yes
  139. - MYSQL_DATABASE={{ database_name }}
  140. - MYSQL_USER={{ database_user }}
  141. - MYSQL_PASSWORD=${DATABASE_PASSWORD}
  142. - MYSQL_CHARSET=utf8mb4
  143. - MYSQL_COLLATION=utf8mb4_unicode_ci
  144. {% elif database_type == 'postgres' %}
  145. - POSTGRES_DB={{ database_name }}
  146. - POSTGRES_USER={{ database_user }}
  147. - POSTGRES_PASSWORD=${DATABASE_PASSWORD}
  148. - POSTGRES_INITDB_ARGS=--encoding=UTF8 --locale=C
  149. {% endif %}
  150. healthcheck:
  151. test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-u", "{{ database_user }}", "-p{{ database_password }}"]
  152. start_period: 30s
  153. interval: 10s
  154. timeout: 10s
  155. retries: 5
  156. {% endif %}
  157. volumes:
  158. - database_data:/var/lib/mysql
  159. {% elif database_type == 'postgres' %}
  160. {{ service_name }}-postgres:
  161. image: docker.io/library/postgres:17.6
  162. {% if not swarm_enabled %}
  163. restart: {{ restart_policy }}
  164. container_name: {{ service_name }}-postgres
  165. {% endif %}
  166. environment:
  167. {% if database_type == 'mysql' %}
  168. - MYSQL_RANDOM_ROOT_PASSWORD=yes
  169. - MYSQL_DATABASE={{ database_name }}
  170. - MYSQL_USER={{ database_user }}
  171. - MYSQL_PASSWORD=${DATABASE_PASSWORD}
  172. - MYSQL_CHARSET=utf8mb4
  173. - MYSQL_COLLATION=utf8mb4_unicode_ci
  174. {% elif database_type == 'postgres' %}
  175. - POSTGRES_DB={{ database_name }}
  176. - POSTGRES_USER={{ database_user }}
  177. - POSTGRES_PASSWORD=${DATABASE_PASSWORD}
  178. - POSTGRES_INITDB_ARGS=--encoding=UTF8 --locale=C
  179. {% endif %}
  180. healthcheck:
  181. test: ["CMD-SHELL", "pg_isready -U {{ database_user }}"]
  182. start_period: 30s
  183. interval: 10s
  184. timeout: 10s
  185. retries: 5
  186. {% endif %}
  187. volumes:
  188. - database_data:/var/lib/postgresql/data
  189. {% endif %}
  190. {% endif %}
  191. {% endif %}
  192. {% if traefik_enabled %}
  193. {{ traefik_network }}:
  194. external: true
  195. {% endif %}
  196. {% endif %}
  197. volumes:
  198. {% if not database_external %}
  199. database_data:
  200. driver: local
  201. {% endif %}