on_unit_inactive_sec 1800
end
+service "promscale-maintenance.timer" do
+ action [:enable, :start]
+end
+
jobs = {}
+search(:node, "roles:gateway") do |gateway|
+ allowed_ips = gateway.interfaces(:role => :internal).map do |interface|
+ "#{interface[:network]}/#{interface[:prefix]}"
+ end
+
+ node.default[:networking][:wireguard][:peers] << {
+ :public_key => gateway[:networking][:wireguard][:public_key],
+ :allowed_ips => allowed_ips,
+ :endpoint => "#{gateway.name}:51820"
+ }
+end
+
search(:node, "recipes:prometheus\\:\\:default").sort_by(&:name).each do |client|
if client[:prometheus][:mode] == "wireguard"
node.default[:networking][:wireguard][:peers] << {
if exporter.is_a?(Hash)
name = exporter[:name]
address = exporter[:address]
+ metric_relabel = exporter[:metric_relabel] || []
else
name = key
address = exporter
+ metric_relabel = []
end
jobs[name] ||= []
- jobs[name] << { :address => address, :name => client.name }
+ jobs[name] << {
+ :address => address,
+ :instance => client.name.split(".").first,
+ :metric_relabel => metric_relabel
+ }
end
end
+template "/etc/default/prometheus" do
+ source "default.prometheus.erb"
+ owner "root"
+ group "root"
+ mode "644"
+end
+
template "/etc/prometheus/prometheus.yml" do
source "prometheus.yml.erb"
owner "root"
variables :jobs => jobs
end
+template "/etc/prometheus/alert_rules.yml" do
+ source "alert_rules.yml.erb"
+ owner "root"
+ group "root"
+ mode "644"
+end
+
service "prometheus" do
action [:enable, :start]
+ subscribes :restart, "template[/etc/default/prometheus]"
subscribes :reload, "template[/etc/prometheus/prometheus.yml]"
+ subscribes :reload, "template[/etc/prometheus/alert_rules.yml]"
+end
+
+template "/etc/default/prometheus-alertmanager" do
+ source "default.alertmanager.erb"
+ owner "root"
+ group "root"
+ mode "644"
end
template "/etc/prometheus/alertmanager.yml" do
service "prometheus-alertmanager" do
action [:enable, :start]
+ subscribes :restart, "template[/etc/default/prometheus-alertmanager]"
subscribes :reload, "template[/etc/prometheus/alertmanager.yml]"
end
+template "/etc/prometheus/amtool.yml" do
+ source "amtool.yml.erb"
+ owner "root"
+ group "root"
+ mode "644"
+end
+
package "grafana-enterprise"
template "/etc/grafana/grafana.ini" do
apache_site "prometheus.openstreetmap.org" do
template "apache.erb"
end
+
+template "/etc/cron.daily/prometheus-backup" do
+ source "backup.cron.erb"
+ owner "root"
+ group "root"
+ mode "750"
+end