compose.yaml.j2.portfix 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. services:
  2. {{ service_name }}:
  3. image: docker.io/grafana/loki:3.5.8
  4. {% if not swarm_enabled %}
  5. restart: {{ restart_policy }}
  6. container_name: {{ container_name }}
  7. {% endif %}
  8. hostname: {{ container_hostname }}
  9. command: "-config.file=/etc/loki/config.yaml"
  10. environment:
  11. - TZ={{ container_timezone }}
  12. - UID={{ user_uid }}
  13. - GID={{ user_gid }}
  14. {% if not traefik_enabled and network_mode == 'bridge' %}
  15. ports:
  16. {% if swarm_enabled %}
  17. - target: 3100
  18. published: {{ ports_http }}
  19. protocol: tcp
  20. mode: host
  21. {% else %}
  22. - "{{ ports_http }}:3100"
  23. {% endif %}
  24. {% endif %}
  25. volumes:
  26. {% if volume_mode == 'mount' %}
  27. - {{ volume_mount_path }}/data:/loki:rw
  28. {% elif volume_mode in ['local', 'nfs'] %}
  29. - {{ service_name }}-data:/loki:rw
  30. {% endif %}
  31. {% if not swarm_enabled %}
  32. {% if volume_mode == 'mount' %}
  33. - {{ volume_mount_path }}/config/config.yaml:/etc/loki/config.yaml:ro
  34. {% else %}
  35. - ./config/config.yaml:/etc/loki/config.yaml:ro
  36. {% endif %}
  37. {% endif %}
  38. {#
  39. When traefik is enabled, add traefik network for reverse proxy access
  40. #}
  41. {% if traefik_enabled %}
  42. networks:
  43. {{ traefik_network }}:
  44. {% endif %}
  45. {% endif %}
  46. {% if swarm_enabled %}
  47. configs:
  48. - source: {{ service_name }}_config
  49. target: /etc/loki/config.yaml
  50. {% endif %}
  51. {% if swarm_enabled or resources_enabled %}
  52. deploy:
  53. {% if swarm_enabled %}
  54. mode: {{ swarm_placement_mode }}
  55. {% if swarm_placement_mode == 'replicated' %}
  56. replicas: {{ swarm_replicas }}
  57. {% endif %}
  58. {% if swarm_placement_host %}
  59. placement:
  60. constraints:
  61. - node.hostname == {{ swarm_placement_host }}
  62. {% endif %}
  63. restart_policy:
  64. condition: on-failure
  65. {% endif %}
  66. {% if resources_enabled %}
  67. resources:
  68. limits:
  69. cpus: '{{ resources_cpu_limit }}'
  70. memory: {{ resources_memory_limit }}
  71. {% if swarm_enabled %}
  72. reservations:
  73. cpus: '{{ resources_cpu_reservation }}'
  74. memory: {{ resources_memory_reservation }}
  75. {% endif %}
  76. {% endif %}
  77. {% if swarm_enabled and traefik_enabled %}
  78. labels:
  79. - traefik.enable=true
  80. - traefik.docker.network={{ traefik_network }}
  81. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=3100
  82. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  83. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  84. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  85. {% if authentik_enabled %}
  86. - traefik.http.routers.{{ service_name }}-http.middlewares={{ authentik_traefik_middleware }}
  87. {% endif %}
  88. {% if traefik_tls_enabled %}
  89. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  90. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  91. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  92. - traefik.http.routers.{{ service_name }}-https.tls=true
  93. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  94. {% if authentik_enabled %}
  95. - traefik.http.routers.{{ service_name }}-https.middlewares={{ authentik_traefik_middleware }}
  96. {% endif %}
  97. {% endif %}
  98. {% endif %}
  99. {% endif %}
  100. {% if traefik_enabled and not swarm_enabled %}
  101. labels:
  102. - traefik.enable=true
  103. - traefik.docker.network={{ traefik_network }}
  104. - traefik.http.services.{{ service_name }}-web.loadBalancer.server.port=3100
  105. - traefik.http.routers.{{ service_name }}-http.service={{ service_name }}-web
  106. - traefik.http.routers.{{ service_name }}-http.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  107. - traefik.http.routers.{{ service_name }}-http.entrypoints={{ traefik_entrypoint }}
  108. {% if authentik_enabled %}
  109. - traefik.http.routers.{{ service_name }}-http.middlewares={{ authentik_traefik_middleware }}
  110. {% endif %}
  111. {% if traefik_tls_enabled %}
  112. - traefik.http.routers.{{ service_name }}-https.service={{ service_name }}-web
  113. - traefik.http.routers.{{ service_name }}-https.rule=Host(`{{ traefik_host }}.{{ traefik_domain }}`)
  114. - traefik.http.routers.{{ service_name }}-https.entrypoints={{ traefik_tls_entrypoint }}
  115. - traefik.http.routers.{{ service_name }}-https.tls=true
  116. - traefik.http.routers.{{ service_name }}-https.tls.certresolver={{ traefik_tls_certresolver }}
  117. {% if authentik_enabled %}
  118. - traefik.http.routers.{{ service_name }}-https.middlewares={{ authentik_traefik_middleware }}
  119. {% endif %}
  120. {% endif %}
  121. {% endif %}
  122. volumes:
  123. {% if volume_mode == 'local' %}
  124. {{ service_name }}-data:
  125. driver: local
  126. {% elif volume_mode == 'nfs' %}
  127. volumes:
  128. {{ service_name }}-data:
  129. driver: local
  130. driver_opts:
  131. type: nfs
  132. o: addr={{ volume_nfs_server }},{{ volume_nfs_options }}
  133. device: ":{{ volume_nfs_path }}/data"
  134. {% endif %}
  135. {% endif %}
  136. {% if traefik_enabled %}
  137. {{ traefik_network }}:
  138. external: true
  139. {% endif %}
  140. {% endif %}
  141. {% if swarm_enabled %}
  142. configs:
  143. {{ service_name }}_config:
  144. file: ./config/config.yaml
  145. {% endif %}