parent
d351213486
commit
14b8efcad2
19 changed files with 311 additions and 364 deletions
@ -0,0 +1,144 @@ |
||||
--- |
||||
|
||||
# matrix-prometheus-services-connect is a role which helps integrate |
||||
# the various Matrix services with the Prometheus role. |
||||
|
||||
# Controls whether Synapse integration should be done |
||||
matrix_prometheus_services_connect_synapse_enabled: false |
||||
|
||||
# Controls whether the synapse rules shall be loaded into Prometheus |
||||
matrix_prometheus_services_connect_synapse_rules_enabled: "{{ matrix_prometheus_services_connect_synapse_enabled }}" |
||||
|
||||
# Controls whether the synapse rules shall be downloaded |
||||
matrix_prometheus_services_connect_synapse_rules_download_enabled: "{{ matrix_prometheus_services_connect_synapse_rules_enabled }}" |
||||
matrix_prometheus_services_connect_synapse_rules_download_synapse_tag: master |
||||
matrix_prometheus_services_connect_synapse_rules_download_src_url: "https://raw.githubusercontent.com/matrix-org/synapse/{{ matrix_prometheus_services_connect_synapse_rules_download_synapse_tag }}/contrib/prometheus/synapse-v2.rules" |
||||
matrix_prometheus_services_connect_synapse_rules_download_dir_path: '' |
||||
matrix_prometheus_services_connect_synapse_rules_download_owner: '' |
||||
matrix_prometheus_services_connect_synapse_rules_download_group: '' |
||||
|
||||
# Controls whether Synapse shall be scraped |
||||
matrix_prometheus_services_connect_scraper_synapse_enabled: false |
||||
|
||||
# Controls scraping the Synapse processes |
||||
matrix_prometheus_services_connect_scraper_synapse_job_name: synapse |
||||
matrix_prometheus_services_connect_scraper_synapse_metrics_path: /_synapse/metrics |
||||
matrix_prometheus_services_connect_scraper_synapse_scrape_interval: 15s |
||||
matrix_prometheus_services_connect_scraper_synapse_scrape_timeout: 15s |
||||
|
||||
matrix_prometheus_services_connect_scraper_synapse_configs: | |
||||
{{ |
||||
[{ |
||||
'job_name': matrix_prometheus_services_connect_scraper_synapse_job_name, |
||||
'metrics_path': matrix_prometheus_services_connect_scraper_synapse_metrics_path, |
||||
'scrape_interval': matrix_prometheus_services_connect_scraper_synapse_scrape_interval, |
||||
'scrape_timeout': matrix_prometheus_services_connect_scraper_synapse_scrape_timeout, |
||||
'static_configs': matrix_prometheus_services_connect_scraper_synapse_static_configs, |
||||
}] |
||||
}} |
||||
|
||||
matrix_prometheus_services_connect_scraper_synapse_static_configs: | |
||||
{{ |
||||
(matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs if matrix_prometheus_services_connect_scraper_synapse_main_process_enabled else []) |
||||
+ |
||||
(matrix_prometheus_services_connect_scraper_synapse_workers_static_configs if matrix_prometheus_services_connect_scraper_synapse_workers_enabled else []) |
||||
}} |
||||
|
||||
# Controls whether the Synapse main process shall be scraped |
||||
matrix_prometheus_services_connect_scraper_synapse_main_process_enabled: "{{ matrix_prometheus_services_connect_scraper_synapse_enabled }}" |
||||
|
||||
matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs: | |
||||
{{ |
||||
[{ |
||||
'targets': [matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs_target], |
||||
'labels': { |
||||
'instance': matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs_instance, |
||||
'job': matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs_job, |
||||
'index': 0, |
||||
} |
||||
}] |
||||
}} |
||||
matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs_target: '' |
||||
matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs_instance: "{{ matrix_domain }}" |
||||
matrix_prometheus_services_connect_scraper_synapse_main_process_static_configs_job: master |
||||
|
||||
# Controls whether Synapse workers shall be scraped |
||||
matrix_prometheus_services_connect_scraper_synapse_workers_enabled: "{{ matrix_prometheus_services_connect_scraper_synapse_enabled and matrix_prometheus_services_connect_scraper_synapse_workers_enabled_list | length > 0 }}" |
||||
|
||||
matrix_prometheus_services_connect_scraper_synapse_workers_enabled_list: [] |
||||
|
||||
matrix_prometheus_services_connect_scraper_synapse_workers_static_configs_as_yaml: | |
||||
{% for worker in matrix_prometheus_services_connect_scraper_synapse_workers_enabled_list %} |
||||
{% if worker.metrics_port != 0 %} |
||||
- targets: ['{{ worker.name }}:{{ worker.metrics_port }}'] |
||||
labels: |
||||
instance: {{ matrix_prometheus_services_connect_scraper_synapse_workers_static_configs_instance | to_json }} |
||||
worker_id: {{ worker.id | to_json }} |
||||
job: {{ worker.type | to_json }} |
||||
app: {{ worker.app | to_json }} |
||||
{% endif %} |
||||
{% endfor %} |
||||
|
||||
matrix_prometheus_services_connect_scraper_synapse_workers_static_configs_instance: "{{ matrix_domain }}" |
||||
|
||||
matrix_prometheus_services_connect_scraper_synapse_workers_static_configs: "{{ [] if matrix_prometheus_services_connect_scraper_synapse_workers_enabled_list | length == 0 else matrix_prometheus_services_connect_scraper_synapse_workers_static_configs_as_yaml | from_yaml }}" |
||||
|
||||
# Controls whether Postgres (postgres-exporter) shall be scraped |
||||
matrix_prometheus_services_connect_scraper_postgres_enabled: false |
||||
matrix_prometheus_services_connect_scraper_postgres_job_name: postgres |
||||
matrix_prometheus_services_connect_scraper_postgres_metrics_path: /metrics |
||||
matrix_prometheus_services_connect_scraper_postgres_scrape_interval: 15s |
||||
matrix_prometheus_services_connect_scraper_postgres_scrape_timeout: 15s |
||||
matrix_prometheus_services_connect_scraper_postgres_static_configs: "{{ [{'targets': [matrix_prometheus_services_connect_scraper_postgres_static_configs_target]}] }}" |
||||
matrix_prometheus_services_connect_scraper_postgres_static_configs_target: '' |
||||
# The final scrape config for the Postgers scraper |
||||
matrix_prometheus_services_connect_scraper_postgres_scrape_configs: | |
||||
{{ |
||||
[{ |
||||
'job_name': matrix_prometheus_services_connect_scraper_postgres_job_name, |
||||
'metrics_path': matrix_prometheus_services_connect_scraper_postgres_metrics_path, |
||||
'scrape_interval': matrix_prometheus_services_connect_scraper_postgres_scrape_interval, |
||||
'scrape_timeout': matrix_prometheus_services_connect_scraper_postgres_scrape_timeout, |
||||
'static_configs': matrix_prometheus_services_connect_scraper_postgres_static_configs, |
||||
}] |
||||
}} |
||||
|
||||
# Controls whether Hookshot shall be scraped |
||||
matrix_prometheus_services_connect_scraper_hookshot_enabled: false |
||||
matrix_prometheus_services_connect_scraper_hookshot_job_name: hookshot |
||||
matrix_prometheus_services_connect_scraper_hookshot_metrics_path: /metrics |
||||
matrix_prometheus_services_connect_scraper_hookshot_scrape_interval: 15s |
||||
matrix_prometheus_services_connect_scraper_hookshot_scrape_timeout: 15s |
||||
matrix_prometheus_services_connect_scraper_hookshot_static_configs: "{{ [{'targets': [matrix_prometheus_services_connect_scraper_hookshot_static_configs_target]}] }}" |
||||
matrix_prometheus_services_connect_scraper_hookshot_static_configs_target: '' |
||||
# The final scrape config for the Hookshot scraper |
||||
matrix_prometheus_services_connect_scraper_hookshot_scrape_configs: | |
||||
{{ |
||||
[{ |
||||
'job_name': matrix_prometheus_services_connect_scraper_hookshot_job_name, |
||||
'metrics_path': matrix_prometheus_services_connect_scraper_hookshot_metrics_path, |
||||
'scrape_interval': matrix_prometheus_services_connect_scraper_hookshot_scrape_interval, |
||||
'scrape_timeout': matrix_prometheus_services_connect_scraper_hookshot_scrape_timeout, |
||||
'static_configs': matrix_prometheus_services_connect_scraper_hookshot_static_configs, |
||||
}] |
||||
}} |
||||
|
||||
# Controls whether nginxlog shall be scraped |
||||
matrix_prometheus_services_connect_scraper_nginxlog_enabled: false |
||||
matrix_prometheus_services_connect_scraper_nginxlog_job_name: nginxlog |
||||
matrix_prometheus_services_connect_scraper_nginxlog_metrics_path: /metrics |
||||
matrix_prometheus_services_connect_scraper_nginxlog_scrape_interval: 15s |
||||
matrix_prometheus_services_connect_scraper_nginxlog_scrape_timeout: 15s |
||||
matrix_prometheus_services_connect_scraper_nginxlog_static_configs: "{{ [{'targets': [matrix_prometheus_services_connect_scraper_nginxlog_static_configs_target]}] }}" |
||||
matrix_prometheus_services_connect_scraper_nginxlog_static_configs_target: '' |
||||
# The final scrape config for the nginxlog scraper |
||||
matrix_prometheus_services_connect_scraper_nginxlog_scrape_configs: | |
||||
{{ |
||||
[{ |
||||
'job_name': matrix_prometheus_services_connect_scraper_nginxlog_job_name, |
||||
'metrics_path': matrix_prometheus_services_connect_scraper_nginxlog_metrics_path, |
||||
'scrape_interval': matrix_prometheus_services_connect_scraper_nginxlog_scrape_interval, |
||||
'scrape_timeout': matrix_prometheus_services_connect_scraper_nginxlog_scrape_timeout, |
||||
'static_configs': matrix_prometheus_services_connect_scraper_nginxlog_static_configs, |
||||
}] |
||||
}} |
@ -0,0 +1,14 @@ |
||||
--- |
||||
|
||||
- name: Download synapse-v2.rules |
||||
ansible.builtin.get_url: |
||||
url: "{{ matrix_prometheus_services_connect_synapse_rules_download_src_url }}" |
||||
dest: "{{ matrix_prometheus_services_connect_synapse_rules_download_dir_path }}/synapse-v2.rules" |
||||
force: true |
||||
mode: 0440 |
||||
owner: "{{ matrix_prometheus_services_connect_synapse_rules_download_owner }}" |
||||
group: "{{ matrix_prometheus_services_connect_synapse_rules_download_group }}" |
||||
register: result |
||||
retries: "{{ devture_playbook_help_geturl_retries_count }}" |
||||
delay: "{{ devture_playbook_help_geturl_retries_delay }}" |
||||
until: result is not failed |
@ -0,0 +1,11 @@ |
||||
--- |
||||
|
||||
- tags: |
||||
- setup-all |
||||
- setup-prometheus |
||||
- setup-prometheus-services-connect |
||||
- install-all |
||||
- install-prometheus-services-connect |
||||
block: |
||||
- when: matrix_prometheus_services_connect_synapse_rules_download_enabled | bool |
||||
ansible.builtin.include_tasks: "{{ role_path }}/tasks/install_synapse_rules.yml" |
@ -1,90 +0,0 @@ |
||||
--- |
||||
# matrix-prometheus is an open-source systems monitoring and alerting toolkit |
||||
# See: https://github.com/matrix-org/synapse/blob/master/docs/metrics-howto.md |
||||
# Project source code URL: https://github.com/prometheus/prometheus |
||||
|
||||
matrix_prometheus_enabled: false |
||||
|
||||
matrix_prometheus_version: v2.42.0 |
||||
matrix_prometheus_docker_image: "{{ matrix_container_global_registry_prefix }}prom/prometheus:{{ matrix_prometheus_version }}" |
||||
matrix_prometheus_docker_image_force_pull: "{{ matrix_prometheus_docker_image.endswith(':latest') }}" |
||||
|
||||
matrix_prometheus_base_path: "{{ matrix_base_data_path }}/prometheus" |
||||
matrix_prometheus_config_path: "{{ matrix_prometheus_base_path }}/config" |
||||
matrix_prometheus_data_path: "{{ matrix_prometheus_base_path }}/data" |
||||
|
||||
# A list of extra arguments to pass to the container |
||||
matrix_prometheus_container_extra_arguments: [] |
||||
|
||||
# List of systemd services that matrix-prometheus.service depends on |
||||
matrix_prometheus_systemd_required_services_list: ['docker.service'] |
||||
|
||||
# List of systemd services that matrix-prometheus.service wants |
||||
matrix_prometheus_systemd_wanted_services_list: [] |
||||
|
||||
# The base container network. It will be auto-created by this role if it doesn't exist already. |
||||
matrix_prometheus_container_network: '' |
||||
|
||||
# A list of additional container networks that the container would be connected to. |
||||
# The role does not create these networks, so make sure they already exist. |
||||
# Use this to expose this container to another reverse proxy, which runs in a different container network. |
||||
matrix_prometheus_container_additional_networks: [] |
||||
|
||||
# Controls whether the matrix-prometheus container exposes its HTTP port (tcp/9090 in the container). |
||||
# |
||||
# Takes an "<ip>:<port>" or "<port>" value (e.g. "127.0.0.1:9090"), or empty string to not expose. |
||||
matrix_prometheus_container_http_host_bind_port: '' |
||||
|
||||
# A list of default arguments to pass to the prometheus process |
||||
matrix_prometheus_process_default_arguments: |
||||
- "--config.file=/etc/prometheus/prometheus.yml" |
||||
- "--storage.tsdb.path=/prometheus" |
||||
- "--web.console.libraries=/usr/share/prometheus/console_libraries" |
||||
- "--web.console.templates=/usr/share/prometheus/consoles" |
||||
|
||||
# A list of extra arguments to pass to the prometheus process |
||||
matrix_prometheus_process_extra_arguments: [] |
||||
|
||||
# holds the final list of process arguments |
||||
matrix_prometheus_process_arguments: "{{ matrix_prometheus_process_default_arguments + matrix_prometheus_process_extra_arguments }}" |
||||
|
||||
# Tells whether the "synapse" scraper configuration is enabled. |
||||
matrix_prometheus_scraper_synapse_enabled: false |
||||
|
||||
# Tells whether to download and load a Synapse rules file |
||||
matrix_prometheus_scraper_synapse_rules_enabled: "{{ matrix_prometheus_scraper_synapse_enabled }}" |
||||
matrix_prometheus_scraper_synapse_rules_synapse_tag: "master" |
||||
matrix_prometheus_scraper_synapse_rules_download_url: "https://raw.githubusercontent.com/matrix-org/synapse/{{ matrix_prometheus_scraper_synapse_rules_synapse_tag }}/contrib/prometheus/synapse-v2.rules" |
||||
|
||||
matrix_prometheus_scraper_synapse_targets: [] |
||||
matrix_prometheus_scraper_synapse_workers_enabled_list: [] |
||||
|
||||
# Tells whether the "node" scraper configuration is enabled. |
||||
# This configuration aims to scrape the current node (this server). |
||||
matrix_prometheus_scraper_node_enabled: false |
||||
|
||||
# Target addresses for the "node" scraper configuration. |
||||
# Unless you define this as a non-empty list, it gets populated at runtime with the IP address of `matrix-prometheus-node-exporter` and port 9100. |
||||
matrix_prometheus_scraper_node_targets: [] |
||||
|
||||
# Default prometheus configuration template which covers the generic use case. |
||||
# You can customize it by controlling the various variables inside it. |
||||
# |
||||
# For a more advanced customization, you can extend the default (see `matrix_prometheus_configuration_extension_yaml`) |
||||
# or completely replace this variable with your own template. |
||||
matrix_prometheus_configuration_yaml: "{{ lookup('template', 'templates/prometheus.yml.j2') }}" |
||||
|
||||
matrix_prometheus_configuration_extension_yaml: | |
||||
# Your custom YAML configuration goes here. |
||||
# This configuration extends the default starting configuration (`matrix_prometheus_configuration_yaml`). |
||||
# |
||||
# You can override individual variables from the default configuration, or introduce new ones. |
||||
# |
||||
# If you need something more special, you can take full control by |
||||
# completely redefining `matrix_prometheus_configuration_yaml`. |
||||
|
||||
matrix_prometheus_configuration_extension: "{{ matrix_prometheus_configuration_extension_yaml | from_yaml if matrix_prometheus_configuration_extension_yaml | from_yaml is mapping else {} }}" |
||||
|
||||
# Holds the final configuration (a combination of the default and its extension). |
||||
# You most likely don't need to touch this variable. Instead, see `matrix_prometheus_configuration_yaml`. |
||||
matrix_prometheus_configuration: "{{ matrix_prometheus_configuration_yaml | from_yaml | combine(matrix_prometheus_configuration_extension, recursive=True) }}" |
@ -1,20 +0,0 @@ |
||||
--- |
||||
|
||||
- tags: |
||||
- setup-all |
||||
- setup-prometheus |
||||
- install-all |
||||
- install-prometheus |
||||
block: |
||||
- when: matrix_prometheus_enabled | bool |
||||
ansible.builtin.include_tasks: "{{ role_path }}/tasks/validate_config.yml" |
||||
|
||||
- when: matrix_prometheus_enabled | bool |
||||
ansible.builtin.include_tasks: "{{ role_path }}/tasks/setup_install.yml" |
||||
|
||||
- tags: |
||||
- setup-all |
||||
- setup-prometheus |
||||
block: |
||||
- when: not matrix_prometheus_enabled | bool |
||||
ansible.builtin.include_tasks: "{{ role_path }}/tasks/setup_uninstall.yml" |
@ -1,57 +0,0 @@ |
||||
--- |
||||
|
||||
- name: Ensure matrix-prometheus image is pulled |
||||
community.docker.docker_image: |
||||
name: "{{ matrix_prometheus_docker_image }}" |
||||
source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" |
||||
force_source: "{{ matrix_prometheus_docker_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}" |
||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_prometheus_docker_image_force_pull }}" |
||||
register: result |
||||
retries: "{{ devture_playbook_help_container_retries_count }}" |
||||
delay: "{{ devture_playbook_help_container_retries_delay }}" |
||||
until: result is not failed |
||||
|
||||
- name: Ensure Prometheus paths exists |
||||
ansible.builtin.file: |
||||
path: "{{ item }}" |
||||
state: directory |
||||
mode: 0750 |
||||
owner: "{{ matrix_user_username }}" |
||||
group: "{{ matrix_user_groupname }}" |
||||
with_items: |
||||
- "{{ matrix_prometheus_base_path }}" |
||||
- "{{ matrix_prometheus_config_path }}" |
||||
- "{{ matrix_prometheus_data_path }}" |
||||
|
||||
- name: Download synapse-v2.rules |
||||
ansible.builtin.get_url: |
||||
url: "{{ matrix_prometheus_scraper_synapse_rules_download_url }}" |
||||
dest: "{{ matrix_prometheus_config_path }}/synapse-v2.rules" |
||||
force: true |
||||
mode: 0440 |
||||
owner: "{{ matrix_user_username }}" |
||||
group: "{{ matrix_user_groupname }}" |
||||
when: "matrix_prometheus_scraper_synapse_rules_enabled | bool" |
||||
register: result |
||||
retries: "{{ devture_playbook_help_geturl_retries_count }}" |
||||
delay: "{{ devture_playbook_help_geturl_retries_delay }}" |
||||
until: result is not failed |
||||
|
||||
- name: Ensure prometheus.yml installed |
||||
ansible.builtin.copy: |
||||
content: "{{ matrix_prometheus_configuration | to_nice_yaml(indent=2, width=999999) }}" |
||||
dest: "{{ matrix_prometheus_config_path }}/prometheus.yml" |
||||
mode: 0644 |
||||
owner: "{{ matrix_user_username }}" |
||||
group: "{{ matrix_user_groupname }}" |
||||
|
||||
- name: Ensure Prometheus container network is created |
||||
community.general.docker_network: |
||||
name: "{{ matrix_prometheus_container_network }}" |
||||
driver: bridge |
||||
|
||||
- name: Ensure matrix-prometheus.service installed |
||||
ansible.builtin.template: |
||||
src: "{{ role_path }}/templates/systemd/matrix-prometheus.service.j2" |
||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-prometheus.service" |
||||
mode: 0644 |
@ -1,20 +0,0 @@ |
||||
--- |
||||
|
||||
- name: Check existence of matrix-prometheus service |
||||
ansible.builtin.stat: |
||||
path: "{{ devture_systemd_docker_base_systemd_path }}/matrix-prometheus.service" |
||||
register: matrix_prometheus_service_stat |
||||
|
||||
- when: matrix_prometheus_service_stat.stat.exists | bool |
||||
block: |
||||
- name: Ensure matrix-prometheus is stopped |
||||
ansible.builtin.service: |
||||
name: matrix-prometheus |
||||
state: stopped |
||||
enabled: false |
||||
daemon_reload: true |
||||
|
||||
- name: Ensure matrix-prometheus.service doesn't exist |
||||
ansible.builtin.file: |
||||
path: "{{ devture_systemd_docker_base_systemd_path }}/matrix-prometheus.service" |
||||
state: absent |
@ -1,15 +0,0 @@ |
||||
--- |
||||
|
||||
- name: Fail if Synapse metrics or Prometheus Node Exporter not enabled |
||||
ansible.builtin.fail: |
||||
msg: > |
||||
You need to enable `matrix_prometheus_scraper_synapse_enabled` and/or `matrix_prometheus_scraper_node_enabled` for Prometheus grab metrics. |
||||
when: "not matrix_prometheus_scraper_synapse_enabled and not matrix_prometheus_scraper_node_enabled" |
||||
|
||||
- name: Fail if required Prometheus settings not defined |
||||
ansible.builtin.fail: |
||||
msg: > |
||||
You need to define a required configuration setting (`{{ item }}`). |
||||
when: "vars[item] == ''" |
||||
with_items: |
||||
- matrix_prometheus_container_network |
@ -1,73 +0,0 @@ |
||||
#jinja2: lstrip_blocks: "True" |
||||
global: |
||||
scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute. |
||||
evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute. |
||||
# scrape_timeout is set to the global default (10s). |
||||
|
||||
# Load rules once and periodically evaluate them according to the global 'evaluation_interval'. |
||||
rule_files: |
||||
{% if matrix_prometheus_scraper_synapse_rules_enabled %} |
||||
- 'synapse-v2.rules' |
||||
{% endif %} |
||||
|
||||
# A scrape configuration containing exactly one endpoint to scrape: |
||||
# Here it's Prometheus itself. |
||||
scrape_configs: |
||||
# The job name is added as a label `job=<job_name>` to any timeseries scraped from this config. |
||||
- job_name: 'prometheus' |
||||
|
||||
# Override the global default and scrape targets from this job every 5 seconds. |
||||
scrape_interval: 5s |
||||
scrape_timeout: 5s |
||||
|
||||
# metrics_path defaults to '/metrics' |
||||
# scheme defaults to 'http'. |
||||
|
||||
static_configs: |
||||
- targets: ['localhost:9090'] |
||||
|
||||
{% if matrix_prometheus_scraper_synapse_enabled %} |
||||
- job_name: 'synapse' |
||||
metrics_path: '/_synapse/metrics' |
||||
static_configs: |
||||
- targets: {{ matrix_prometheus_scraper_synapse_targets|to_json }} |
||||
labels: |
||||
instance: {{ matrix_domain | to_json }} |
||||
job: master |
||||
index: 0 |
||||
{% for worker in matrix_prometheus_scraper_synapse_workers_enabled_list %} |
||||
{% if worker.metrics_port != 0 %} |
||||
- targets: ['{{ worker.name }}:{{ worker.metrics_port }}'] |
||||
labels: |
||||
instance: {{ matrix_domain | to_json }} |
||||
worker_id: {{ worker.id | to_json }} |
||||
job: {{ worker.type | to_json }} |
||||
app: {{ worker.app | to_json }} |
||||
{% endif %} |
||||
{% endfor %} |
||||
{% endif %} |
||||
|
||||
{% if matrix_prometheus_scraper_node_enabled %} |
||||
- job_name: node |
||||
static_configs: |
||||
- targets: {{ matrix_prometheus_scraper_node_targets|to_json }} |
||||
{% endif %} |
||||
|
||||
{% if matrix_prometheus_scraper_postgres_enabled %} |
||||
- job_name: postgres |
||||
static_configs: |
||||
- targets: {{ matrix_prometheus_scraper_postgres_targets|to_json }} |
||||
{% endif %} |
||||
|
||||
{% if matrix_prometheus_scraper_hookshot_enabled %} |
||||
- job_name: hookshot |
||||
static_configs: |
||||
- targets: {{ matrix_prometheus_scraper_hookshot_targets|to_json }} |
||||
{% endif %} |
||||
|
||||
{% if matrix_prometheus_scraper_nginxlog_enabled %} |
||||
- job_name: nginxlog |
||||
static_configs: |
||||
- targets: |
||||
- {{ matrix_prometheus_scraper_nginxlog_server_port}} |
||||
{% endif %} |
@ -1,51 +0,0 @@ |
||||
#jinja2: lstrip_blocks: "True" |
||||
[Unit] |
||||
Description=matrix-prometheus |
||||
{% for service in matrix_prometheus_systemd_required_services_list %} |
||||
Requires={{ service }} |
||||
After={{ service }} |
||||
{% endfor %} |
||||
{% for service in matrix_prometheus_systemd_wanted_services_list %} |
||||
Wants={{ service }} |
||||
{% endfor %} |
||||
DefaultDependencies=no |
||||
|
||||
[Service] |
||||
Type=simple |
||||
Environment="HOME={{ devture_systemd_docker_base_systemd_unit_home_path }}" |
||||
ExecStartPre=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} kill matrix-prometheus 2>/dev/null || true' |
||||
ExecStartPre=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} rm matrix-prometheus 2>/dev/null || true' |
||||
|
||||
ExecStartPre={{ devture_systemd_docker_base_host_command_docker }} create \ |
||||
--rm \ |
||||
--name=matrix-prometheus \ |
||||
--log-driver=none \ |
||||
--user={{ matrix_user_uid }}:{{ matrix_user_gid }} \ |
||||
--cap-drop=ALL \ |
||||
--read-only \ |
||||
--network={{ matrix_prometheus_container_network }} \ |
||||
{% if matrix_prometheus_container_http_host_bind_port %} |
||||
-p {{ matrix_prometheus_container_http_host_bind_port }}:9090 \ |
||||
{% endif %} |
||||
-v {{ matrix_prometheus_config_path }}:/etc/prometheus:z \ |
||||
-v {{ matrix_prometheus_data_path }}:/prometheus:z \ |
||||
{% for arg in matrix_prometheus_container_extra_arguments %} |
||||
{{ arg }} \ |
||||
{% endfor %} |
||||
{{ matrix_prometheus_docker_image }} {{ matrix_prometheus_process_arguments|join(' ') }} |
||||
|
||||
{% for network in matrix_prometheus_container_additional_networks %} |
||||
ExecStartPre={{ devture_systemd_docker_base_host_command_docker }} network connect {{ network }} matrix-prometheus |
||||
{% endfor %} |
||||
|
||||
ExecStart={{ devture_systemd_docker_base_host_command_docker }} start --attach matrix-prometheus |
||||
|
||||
ExecStop=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} kill matrix-prometheus 2>/dev/null || true' |
||||
ExecStop=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} rm matrix-prometheus 2>/dev/null || true' |
||||
|
||||
Restart=always |
||||
RestartSec=30 |
||||
SyslogIdentifier=matrix-prometheus |
||||
|
||||
[Install] |
||||
WantedBy=multi-user.target |
Loading…
Reference in new issue