Merge "Allow to deploy prometheus as standalone service"
This commit is contained in:
commit
b13e62b904
16 changed files with 347 additions and 75 deletions
11
README.rst
11
README.rst
|
@ -160,6 +160,17 @@ Configure pushgateway
|
||||||
enabled: true
|
enabled: true
|
||||||
external_port: 15012
|
external_port: 15012
|
||||||
|
|
||||||
|
Install prometheus as service
|
||||||
|
-------------------------------------
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
parameters:
|
||||||
|
prometheus:
|
||||||
|
server:
|
||||||
|
is_container: false
|
||||||
|
|
||||||
|
|
||||||
Documentation and Bugs
|
Documentation and Bugs
|
||||||
======================
|
======================
|
||||||
|
|
||||||
|
|
10
metadata/service/relay/cluster.yml
Normal file
10
metadata/service/relay/cluster.yml
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
parameters:
|
||||||
|
prometheus:
|
||||||
|
relay:
|
||||||
|
backends:
|
||||||
|
- host: ${_param:cluster_node01_address}
|
||||||
|
port: ${_param:prometheus_server_bind_port}
|
||||||
|
- host: ${_param:cluster_node02_address}
|
||||||
|
port: ${_param:prometheus_server_bind_port}
|
||||||
|
- host: ${_param:cluster_node03_address}
|
||||||
|
port: ${_param:prometheus_server_bind_port}
|
12
metadata/service/relay/init.yml
Normal file
12
metadata/service/relay/init.yml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
applications:
|
||||||
|
- prometheus
|
||||||
|
classes:
|
||||||
|
- service.prometheus.support
|
||||||
|
parameters:
|
||||||
|
_param:
|
||||||
|
prometheus_relay_bind_port: 8080
|
||||||
|
prometheus:
|
||||||
|
relay:
|
||||||
|
enabled: true
|
||||||
|
bind:
|
||||||
|
port: ${_param:prometheus_relay_bind_port}
|
|
@ -11,6 +11,11 @@ parameters:
|
||||||
prometheus:
|
prometheus:
|
||||||
server:
|
server:
|
||||||
enabled: true
|
enabled: true
|
||||||
|
is_container: true
|
||||||
|
use_grains:
|
||||||
|
target: true
|
||||||
|
recording: true
|
||||||
|
alert: true
|
||||||
dir:
|
dir:
|
||||||
config: /srv/volumes/prometheus/server
|
config: /srv/volumes/prometheus/server
|
||||||
config_in_container: /srv/prometheus
|
config_in_container: /srv/prometheus
|
||||||
|
|
37
metadata/service/server/standalone.yml
Normal file
37
metadata/service/server/standalone.yml
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
applications:
|
||||||
|
- prometheus
|
||||||
|
classes:
|
||||||
|
- service.prometheus.support
|
||||||
|
parameters:
|
||||||
|
_param:
|
||||||
|
prometheus_evaluation_interval: "15s"
|
||||||
|
prometheus_region_label: "region1"
|
||||||
|
prometheus_scrape_interval: "15s"
|
||||||
|
prometheus_storage_retention: "4320h"
|
||||||
|
prometheus_server_bind_port: 9090
|
||||||
|
prometheus:
|
||||||
|
server:
|
||||||
|
enabled: true
|
||||||
|
is_container: false
|
||||||
|
use_grains:
|
||||||
|
target: false
|
||||||
|
recording: false
|
||||||
|
alert: false
|
||||||
|
dir:
|
||||||
|
config: /etc/prometheus
|
||||||
|
data: /var/lib/prometheus/data
|
||||||
|
bind:
|
||||||
|
port: ${_param:prometheus_server_bind_port}
|
||||||
|
address: 0.0.0.0
|
||||||
|
storage:
|
||||||
|
local:
|
||||||
|
retention: ${_param:prometheus_storage_retention}
|
||||||
|
alertmanager:
|
||||||
|
notification_queue_capacity: 10000
|
||||||
|
config:
|
||||||
|
global:
|
||||||
|
scrape_interval: ${_param:prometheus_scrape_interval}
|
||||||
|
scrape_timeout: "15s"
|
||||||
|
evaluation_interval: ${_param:prometheus_evaluation_interval}
|
||||||
|
external_labels:
|
||||||
|
region: ${_param:prometheus_region_label}
|
10
prometheus/files/relay/default
Normal file
10
prometheus/files/relay/default
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{%- from "prometheus/map.jinja" import relay with context %}
|
||||||
|
{%- if relay.get("backends") %}
|
||||||
|
{%- set relay_backends = [] %}
|
||||||
|
{%- for backend in relay.backends %}
|
||||||
|
{%- set address = "%s:%d" | format(backend.host, backend.port) %}
|
||||||
|
{%- do relay_backends.append(address) %}
|
||||||
|
{%- endfor %}
|
||||||
|
PROMETHEUS_RELAY_BACKENDS={{ relay_backends | join(',') }}
|
||||||
|
{%- endif %}
|
||||||
|
PROMETHEUS_RELAY_BIND_PORT={{ relay.bind.port }}
|
18
prometheus/files/relay/service
Normal file
18
prometheus/files/relay/service
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
{%- from "prometheus/map.jinja" import relay with context %}
|
||||||
|
[Unit]
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=root
|
||||||
|
EnvironmentFile=-/etc/default/prometheus-relay
|
||||||
|
ExecStart=/usr/bin/prometheus-relay \
|
||||||
|
-port=${PROMETHEUS_RELAY_BIND_PORT} \
|
||||||
|
{%- if relay.get("backends") %}
|
||||||
|
-urls=${PROMETHEUS_RELAY_BACKENDS}
|
||||||
|
{%- endif %}
|
||||||
|
ExecReload=/bin/kill -HUP $MAINPID
|
||||||
|
Restart=on-failure
|
||||||
|
KillMode=control-group
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
|
@ -1,14 +1,14 @@
|
||||||
{%- from "prometheus/map.jinja" import server with context %}
|
|
||||||
|
|
||||||
{%- set alerts = {} %}
|
{%- set alerts = {} %}
|
||||||
{%- set recordings = {} %}
|
{%- set recordings = {} %}
|
||||||
|
|
||||||
|
{%- if server.get('use_grains', {}).get('recording', True) %}
|
||||||
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
||||||
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
||||||
{%- for recordingname, recording in server_grain.get('recording', {}).iteritems() %}
|
{%- for recordingname, recording in server_grain.get('recording', {}).iteritems() %}
|
||||||
{%- do recordings.update({recordingname: recording}) %}
|
{%- do recordings.update({recordingname: recording}) %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
{%- set recordings = salt['grains.filter_by']({'default': recordings}, merge=server.get('recording', {})) %}
|
{%- set recordings = salt['grains.filter_by']({'default': recordings}, merge=server.get('recording', {})) %}
|
||||||
|
|
||||||
|
@ -18,12 +18,14 @@
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
|
||||||
|
{%- if server.get('use_grains', {}).get('alert', True) %}
|
||||||
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
||||||
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
||||||
{%- for alertname, alert in server_grain.get('alert', {}).iteritems() %}
|
{%- for alertname, alert in server_grain.get('alert', {}).iteritems() %}
|
||||||
{%- do alerts.update({alertname: alert}) %}
|
{%- do alerts.update({alertname: alert}) %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
{%- set alerts = salt['grains.filter_by']({'default': alerts}, merge=server.get('alert', {})) %}
|
{%- set alerts = salt['grains.filter_by']({'default': alerts}, merge=server.get('alert', {})) %}
|
||||||
|
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
{%- from "prometheus/map.jinja" import server with context %}
|
|
||||||
|
|
||||||
{%- set alerts = {} %}
|
{%- set alerts = {} %}
|
||||||
{%- set recordings = {} %}
|
{%- set recordings = {} %}
|
||||||
|
|
||||||
|
{%- if server.get('use_grains', {}).get('recording', True) %}
|
||||||
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
||||||
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
||||||
{%- for recordingname, recording in server_grain.get('recording', {}).iteritems() %}
|
{%- for recordingname, recording in server_grain.get('recording', {}).iteritems() %}
|
||||||
{%- do recordings.update({recordingname: recording}) %}
|
{%- do recordings.update({recordingname: recording}) %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
groups:
|
groups:
|
||||||
{%- set recordings = salt['grains.filter_by']({'default': recordings}, merge=server.get('recording', {})) %}
|
{%- set recordings = salt['grains.filter_by']({'default': recordings}, merge=server.get('recording', {})) %}
|
||||||
|
@ -19,15 +19,19 @@ groups:
|
||||||
- record: {{ recordingname }}
|
- record: {{ recordingname }}
|
||||||
expr: >-
|
expr: >-
|
||||||
{{ recording.query | indent(6, False) }}
|
{{ recording.query | indent(6, False) }}
|
||||||
|
labels:
|
||||||
|
recording_label: {{ recording.get('label', server.get('recording_label', 'federation')) }}
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
|
||||||
|
{%- if server.get('use_grains', {}).get('alert', True) %}
|
||||||
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
||||||
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
{%- set server_grain = node_grains.get('prometheus', {}).get('server', {}) %}
|
||||||
{%- for alertname, alert in server_grain.get('alert', {}).iteritems() %}
|
{%- for alertname, alert in server_grain.get('alert', {}).iteritems() %}
|
||||||
{%- do alerts.update({alertname: alert}) %}
|
{%- do alerts.update({alertname: alert}) %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
{%- set alerts = salt['grains.filter_by']({'default': alerts}, merge=server.get('alert', {})) %}
|
{%- set alerts = salt['grains.filter_by']({'default': alerts}, merge=server.get('alert', {})) %}
|
||||||
- name: alert.rules
|
- name: alert.rules
|
||||||
|
|
5
prometheus/files/server/default
Normal file
5
prometheus/files/server/default
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{% from "prometheus/map.jinja" import server with context %}
|
||||||
|
PROMETHEUS_CONFIG_DIR={{ server.dir.config }}
|
||||||
|
PROMETHEUS_DATA_DIR={{ server.dir.data }}
|
||||||
|
PROMETHEUS_BIND_ADDRESS={{ server.bind.address }}:{{ server.bind.port }}
|
||||||
|
PROMETHEUS_STORAGE_LOCAL_RETENTION={{ server.storage.local.retention }}
|
|
@ -1,5 +1,3 @@
|
||||||
{%- from "prometheus/map.jinja" import server with context %}
|
|
||||||
|
|
||||||
global:
|
global:
|
||||||
{%- if server.get('config', {}).global is defined %}
|
{%- if server.get('config', {}).global is defined %}
|
||||||
{{ server.config.global | yaml(False) | indent(2, true) }}
|
{{ server.config.global | yaml(False) | indent(2, true) }}
|
||||||
|
@ -38,6 +36,7 @@ rule_files:
|
||||||
- alerts.yml
|
- alerts.yml
|
||||||
|
|
||||||
{%- set static_target = server.target.static %}
|
{%- set static_target = server.target.static %}
|
||||||
|
{%- if server.get('use_grains', {}).get('target', True) %}
|
||||||
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
||||||
{%- set static_grain = node_grains.get('prometheus', {}).get('server', {}).get('target', {}).get('static', {}) %}
|
{%- set static_grain = node_grains.get('prometheus', {}).get('server', {}).get('target', {}).get('static', {}) %}
|
||||||
{%- for job_name, job in static_grain.iteritems() %}
|
{%- for job_name, job in static_grain.iteritems() %}
|
||||||
|
@ -45,6 +44,9 @@ rule_files:
|
||||||
{%- do static_target.update({job_name: {
|
{%- do static_target.update({job_name: {
|
||||||
'enabled': job.get('enabled', True),
|
'enabled': job.get('enabled', True),
|
||||||
'metrics_path': job.get('metrics_path', '/metrics'),
|
'metrics_path': job.get('metrics_path', '/metrics'),
|
||||||
|
'honor_labels': job.get('honor_labels', False),
|
||||||
|
'scrape_interval': job.get('scrape_interval', server.get('config', {}).get('global', {}).get('scrape_interval', '15s')),
|
||||||
|
'scrape_timeout': job.get('scrape_interval', server.get('config', {}).get('global', {}).get('scrape_interval', '15s')),
|
||||||
'scheme': job.get('scheme', 'http')}
|
'scheme': job.get('scheme', 'http')}
|
||||||
}) %}
|
}) %}
|
||||||
{%- if job.get('tls_config') %}
|
{%- if job.get('tls_config') %}
|
||||||
|
@ -71,6 +73,7 @@ rule_files:
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
scrape_configs:
|
scrape_configs:
|
||||||
{%- for job_name, job in static_target.iteritems() %}
|
{%- for job_name, job in static_target.iteritems() %}
|
||||||
|
@ -83,6 +86,15 @@ scrape_configs:
|
||||||
- job_name: {{ job_name }}
|
- job_name: {{ job_name }}
|
||||||
{% if job.get('scheme') %}scheme: {{ job.scheme }}{%- endif %}
|
{% if job.get('scheme') %}scheme: {{ job.scheme }}{%- endif %}
|
||||||
{% if job.get('metrics_path') %}metrics_path: {{ job.metrics_path }}{%- endif %}
|
{% if job.get('metrics_path') %}metrics_path: {{ job.metrics_path }}{%- endif %}
|
||||||
|
{% if job.honor_labels is defined %}honor_labels: {{ job.honor_labels }}{%- endif %}
|
||||||
|
{% if job.scrape_interval is defined %}scrape_interval: {{ job.scrape_interval }}{%- endif %}
|
||||||
|
{% if job.scrape_timeout is defined %}scrape_timeout: {{ job.scrape_timeout }}{%- endif %}
|
||||||
|
{%- if job.get('params') %}
|
||||||
|
params:
|
||||||
|
{%- for param_name, param_value in job.get('params', {}).iteritems() %}
|
||||||
|
{{ param_name }}: {{ param_value }}
|
||||||
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
{%- if job.get('tls_config') %}
|
{%- if job.get('tls_config') %}
|
||||||
tls_config:
|
tls_config:
|
||||||
{% if job.tls_config.get('skip_verify') is defined %}insecure_skip_verify: {{ job.tls_config.skip_verify | lower }}{%- endif %}
|
{% if job.tls_config.get('skip_verify') is defined %}insecure_skip_verify: {{ job.tls_config.skip_verify | lower }}{%- endif %}
|
||||||
|
@ -120,12 +132,14 @@ scrape_configs:
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
|
||||||
{%- set kubernetes_target = {} %}
|
{%- set kubernetes_target = {} %}
|
||||||
|
{%- if server.get('use_grains', {}).get('target', True) %}
|
||||||
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
|
||||||
{%- set kubernetes_grain = node_grains.get('prometheus', {}).get('server', {}).get('target', {}).get('kubernetes', {}) %}
|
{%- set kubernetes_grain = node_grains.get('prometheus', {}).get('server', {}).get('target', {}).get('kubernetes', {}) %}
|
||||||
{%- if kubernetes_grain %}
|
{%- if kubernetes_grain %}
|
||||||
{%- do kubernetes_target.update(kubernetes_grain) %}
|
{%- do kubernetes_target.update(kubernetes_grain) %}
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
{%- if kubernetes_target.get('enabled', False) %}
|
{%- if kubernetes_target.get('enabled', False) %}
|
||||||
|
|
||||||
|
|
18
prometheus/files/server/service
Normal file
18
prometheus/files/server/service
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
[Unit]
|
||||||
|
Description=Prometheus Server
|
||||||
|
Documentation=https://prometheus.io/docs/introduction/overview/
|
||||||
|
After=network-online.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
EnvironmentFile=-/etc/default/prometheus
|
||||||
|
User=root
|
||||||
|
Group=root
|
||||||
|
Restart=on-failure
|
||||||
|
ExecStart=/usr/bin/prometheus \
|
||||||
|
--web.listen-address=${PROMETHEUS_BIND_ADDRESS} \
|
||||||
|
--config.file=${PROMETHEUS_CONFIG_DIR}/prometheus.yml \
|
||||||
|
--storage.tsdb.path=${PROMETHEUS_DATA_DIR} \
|
||||||
|
--storage.tsdb.retention=${PROMETHEUS_STORAGE_LOCAL_RETENTION}
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
|
@ -1,10 +1,14 @@
|
||||||
{%- if pillar.prometheus.server is defined or
|
{%- if pillar.prometheus.get('server', {}).get('enabled', False) or
|
||||||
|
pillar.prometheus.get('relay', {}).get('enabled', False) or
|
||||||
pillar.prometheus.alertmanager is defined or
|
pillar.prometheus.alertmanager is defined or
|
||||||
pillar.prometheus.exporters is defined %}
|
pillar.prometheus.exporters is defined %}
|
||||||
include:
|
include:
|
||||||
{%- if pillar.prometheus.server is defined %}
|
{%- if pillar.prometheus.get('server', {}).get('enabled', False) %}
|
||||||
- prometheus.server
|
- prometheus.server
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
|
{%- if pillar.prometheus.get('relay', {}).get('enabled', False) %}
|
||||||
|
- prometheus.relay
|
||||||
|
{%- endif %}
|
||||||
{%- if pillar.prometheus.alertmanager is defined %}
|
{%- if pillar.prometheus.alertmanager is defined %}
|
||||||
- prometheus.alertmanager
|
- prometheus.alertmanager
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
{% set server = salt['grains.filter_by']({
|
{% set server = salt['grains.filter_by']({
|
||||||
'default': {
|
'default': {
|
||||||
'version': 2.0,
|
'version': 2.0,
|
||||||
|
'pkgs': ['prometheus-bin'],
|
||||||
'target': {
|
'target': {
|
||||||
'static': {
|
'static': {
|
||||||
},
|
},
|
||||||
|
@ -8,6 +9,12 @@
|
||||||
},
|
},
|
||||||
}, merge=salt['pillar.get']('prometheus:server')) %}
|
}, merge=salt['pillar.get']('prometheus:server')) %}
|
||||||
|
|
||||||
|
{% set relay = salt['grains.filter_by']({
|
||||||
|
'default': {
|
||||||
|
'pkgs': ['prometheus-relay']
|
||||||
|
},
|
||||||
|
}, merge=salt['pillar.get']('prometheus:relay')) %}
|
||||||
|
|
||||||
{% set alertmanager = salt['grains.filter_by']({
|
{% set alertmanager = salt['grains.filter_by']({
|
||||||
'default': {
|
'default': {
|
||||||
},
|
},
|
||||||
|
|
53
prometheus/relay.sls
Normal file
53
prometheus/relay.sls
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
{% from "prometheus/map.jinja" import relay with context %}
|
||||||
|
{%- if relay.enabled %}
|
||||||
|
|
||||||
|
prometheus_relay_packages:
|
||||||
|
pkg.installed:
|
||||||
|
- names: {{ relay.pkgs }}
|
||||||
|
|
||||||
|
prometheus_relay_default_file:
|
||||||
|
file.managed:
|
||||||
|
- name: /etc/default/prometheus-relay
|
||||||
|
- source: salt://prometheus/files/relay/default
|
||||||
|
- template: jinja
|
||||||
|
|
||||||
|
{%- if grains.get('init') == 'systemd' %}
|
||||||
|
|
||||||
|
prometheus_relay_systemd_config:
|
||||||
|
file.managed:
|
||||||
|
- name: /etc/systemd/system/prometheus-relay.service
|
||||||
|
- source: salt://prometheus/files/relay/service
|
||||||
|
- makedirs: true
|
||||||
|
- user: root
|
||||||
|
- group: root
|
||||||
|
- mode: 644
|
||||||
|
- template: jinja
|
||||||
|
- require:
|
||||||
|
- file: prometheus_relay_default_file
|
||||||
|
|
||||||
|
prometheus_relay_restart_systemd:
|
||||||
|
module.wait:
|
||||||
|
- name: service.systemctl_reload
|
||||||
|
- watch:
|
||||||
|
- file: prometheus_relay_systemd_config
|
||||||
|
- watch_in:
|
||||||
|
- service: prometheus_relay_service
|
||||||
|
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
|
prometheus_relay_service:
|
||||||
|
service.running:
|
||||||
|
- name: prometheus-relay
|
||||||
|
- enable: True
|
||||||
|
{%- if grains.get('noservices') %}
|
||||||
|
- onlyif: /bin/false
|
||||||
|
{%- endif %}
|
||||||
|
- watch:
|
||||||
|
{%- if grains.get('init') == 'systemd' %}
|
||||||
|
- file: prometheus_relay_systemd_config
|
||||||
|
{%- endif %}
|
||||||
|
- file: prometheus_relay_default_file
|
||||||
|
- require:
|
||||||
|
- pkg: prometheus_relay_packages
|
||||||
|
|
||||||
|
{%- endif %}
|
|
@ -1,30 +1,92 @@
|
||||||
{% from "prometheus/map.jinja" import server with context %}
|
{% from "prometheus/map.jinja" import server with context %}
|
||||||
{%- if server.enabled %}
|
{%- if server.enabled %}
|
||||||
|
|
||||||
{%- if pillar.docker is defined and pillar.docker.host is defined %}
|
prometheus_server_config_dir:
|
||||||
|
|
||||||
{{server.dir.config}}:
|
|
||||||
file.directory:
|
file.directory:
|
||||||
|
- name: {{ server.dir.config }}
|
||||||
- makedirs: True
|
- makedirs: True
|
||||||
|
|
||||||
{{server.dir.data}}:
|
prometheus_server_data_dir:
|
||||||
file.directory:
|
file.directory:
|
||||||
|
- name: {{ server.dir.data }}
|
||||||
- makedirs: True
|
- makedirs: True
|
||||||
- mode: 755
|
- mode: 755
|
||||||
|
|
||||||
{{server.dir.config}}/prometheus.yml:
|
prometheus_server_config_file:
|
||||||
file.managed:
|
file.managed:
|
||||||
|
- name: {{ server.dir.config }}/prometheus.yml
|
||||||
- source: salt://prometheus/files/server/prometheus.yml
|
- source: salt://prometheus/files/server/prometheus.yml
|
||||||
- template: jinja
|
- template: jinja
|
||||||
|
- defaults:
|
||||||
|
server: {{ server }}
|
||||||
- require:
|
- require:
|
||||||
- file: {{server.dir.config}}
|
- file: prometheus_server_config_dir
|
||||||
|
|
||||||
{{server.dir.config}}/alerts.yml:
|
prometheus_server_alerts_file:
|
||||||
file.managed:
|
file.managed:
|
||||||
|
- name: {{ server.dir.config }}/alerts.yml
|
||||||
- source: salt://prometheus/files/server/{{server.version}}/alerts.yml
|
- source: salt://prometheus/files/server/{{server.version}}/alerts.yml
|
||||||
- template: jinja
|
- template: jinja
|
||||||
|
- defaults:
|
||||||
|
server: {{ server }}
|
||||||
- require:
|
- require:
|
||||||
- file: {{server.dir.config}}
|
- file: prometheus_server_config_dir
|
||||||
|
|
||||||
|
{%- if not server.get('is_container', True) %}
|
||||||
|
|
||||||
|
prometheus_server_packages:
|
||||||
|
pkg.installed:
|
||||||
|
- names: {{ server.pkgs }}
|
||||||
|
|
||||||
|
prometheus_server_default_file:
|
||||||
|
file.managed:
|
||||||
|
- name: /etc/default/prometheus
|
||||||
|
- source: salt://prometheus/files/server/default
|
||||||
|
- template: jinja
|
||||||
|
- defaults:
|
||||||
|
server: {{ server }}
|
||||||
|
|
||||||
|
{%- if grains.get('init') == 'systemd' %}
|
||||||
|
|
||||||
|
prometheus_server_systemd_config:
|
||||||
|
file.managed:
|
||||||
|
- name: /etc/systemd/system/prometheus.service
|
||||||
|
- source: salt://prometheus/files/server/service
|
||||||
|
- makedirs: true
|
||||||
|
- user: root
|
||||||
|
- group: root
|
||||||
|
- mode: 644
|
||||||
|
- template: jinja
|
||||||
|
- require:
|
||||||
|
- file: prometheus_server_default_file
|
||||||
|
|
||||||
|
prometheus_server_restart_systemd:
|
||||||
|
module.wait:
|
||||||
|
- name: service.systemctl_reload
|
||||||
|
- watch:
|
||||||
|
- file: prometheus_server_systemd_config
|
||||||
|
- watch_in:
|
||||||
|
- service: prometheus_server_service
|
||||||
|
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
|
|
||||||
|
prometheus_server_service:
|
||||||
|
service.running:
|
||||||
|
- name: prometheus
|
||||||
|
- enable: True
|
||||||
|
{%- if grains.get('noservices') %}
|
||||||
|
- onlyif: /bin/false
|
||||||
|
{%- endif %}
|
||||||
|
- watch:
|
||||||
|
{%- if grains.get('init') == 'systemd' %}
|
||||||
|
- file: prometheus_server_systemd_config
|
||||||
|
{%- endif %}
|
||||||
|
- file: prometheus_server_config_file
|
||||||
|
- file: prometheus_server_alerts_file
|
||||||
|
- require:
|
||||||
|
- file: prometheus_server_data_dir
|
||||||
|
- pkg: prometheus_server_packages
|
||||||
|
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
|
|
Loading…
Reference in a new issue