X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/acd1a016748bd3f8b47b370b9a7c15cbf44162f1..e88de84c8ea440ad2da805a9529bfb1689a8fa72:/cookbooks/prometheus/recipes/server.rb diff --git a/cookbooks/prometheus/recipes/server.rb b/cookbooks/prometheus/recipes/server.rb index e10e9e4ce..571714c50 100644 --- a/cookbooks/prometheus/recipes/server.rb +++ b/cookbooks/prometheus/recipes/server.rb @@ -20,11 +20,127 @@ include_recipe "apache" include_recipe "apt" include_recipe "networking" +include_recipe "timescaledb" passwords = data_bag_item("prometheus", "passwords") +tokens = data_bag_item("prometheus", "tokens") + +prometheus_exporter "fastly" do + port 8080 + listen_switch "endpoint" + listen_type "url" + environment "FASTLY_API_TOKEN" => tokens["fastly"] +end package "prometheus" +promscale_version = "0.1.4" + +database_cluster = node[:timescaledb][:cluster] + +postgresql_user "prometheus" do + cluster database_cluster + createrole true +end + +postgresql_database "promscale" do + cluster database_cluster + owner "prometheus" +end + +postgresql_extension "timescaledb" do + cluster database_cluster + database "promscale" +end + +directory "/opt/promscale" do + owner "root" + group "root" + mode "755" +end + +package %w[ + make + gcc + clang-9 + llvm-9 + cargo +] + +git "/opt/promscale/extension" do + action :sync + repository "https://github.com/timescale/promscale_extension.git" + revision "0.1.1" + user "root" + group "root" +end + +execute "/opt/promscale/extension/Makefile" do + action :nothing + command "make install" + cwd "/opt/promscale/extension" + user "root" + group "root" + subscribes :run, "git[/opt/promscale/extension]", :immediately + notifies :restart, "service[postgresql]", :immediately +end + +directory "/opt/promscale/bin" do + owner "root" + group "root" + mode "755" +end + +remote_file "/opt/promscale/bin/promscale" do + action :create + source "https://github.com/timescale/promscale/releases/download/#{promscale_version}/promscale_#{promscale_version}_Linux_x86_64" + owner "root" + group "root" + mode "755" +end + +systemd_service "promscale" do + description "Promscale Connector" + type "simple" + user "prometheus" + exec_start "/opt/promscale/bin/promscale --db-host /run/postgresql --db-port 5432 --db-user prometheus --db-name promscale --db-connections-max 400" + # exec_start lazy { "/opt/promscale/bin/promscale --db-host /run/postgresql --db-port #{node[:postgresql][:clusters][database_cluster][:port]} --db-user prometheus --db-name promscale --db-max-connections 400" } + limit_nofile 16384 + private_tmp true + protect_system "strict" + protect_home true + no_new_privileges true +end + +service "promscale" do + action [:enable, :start] + subscribes :restart, "remote_file[/opt/promscale/bin/promscale]" + subscribes :restart, "systemd_service[promscale]" +end + +postgresql_extension "promscale" do + cluster database_cluster + database "promscale" + notifies :restart, "service[promscale]" +end + +systemd_service "promscale-maintenance" do + description "Promscale Maintenace" + type "simple" + user "prometheus" + exec_start "/usr/bin/psql --command='CALL prom_api.execute_maintenance()' promscale" + private_tmp true + protect_system "strict" + protect_home true + no_new_privileges true +end + +systemd_timer "promscale-maintenance" do + description "Promscale Maintenace" + on_active_sec 1800 + on_unit_inactive_sec 1800 +end + jobs = {} search(:node, "recipes:prometheus\\:\\:default").sort_by(&:name).each do |client| @@ -36,7 +152,15 @@ search(:node, "recipes:prometheus\\:\\:default").sort_by(&:name).each do |client } end - client[:prometheus][:exporters].each do |name, address| + client[:prometheus][:exporters].each do |key, exporter| + if exporter.is_a?(Hash) + name = exporter[:name] + address = exporter[:address] + else + name = key + address = exporter + end + jobs[name] ||= [] jobs[name] << { :address => address, :name => client.name } end