X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/a68415b8f2bf106b6ea5948b0605c897b516ef4f..90089d0d43c121bc09f54d060ae96d8b13645727:/cookbooks/ntp/recipes/default.rb?ds=sidebyside diff --git a/cookbooks/ntp/recipes/default.rb b/cookbooks/ntp/recipes/default.rb index 29f79d693..3a9b0bb8b 100644 --- a/cookbooks/ntp/recipes/default.rb +++ b/cookbooks/ntp/recipes/default.rb @@ -1,15 +1,15 @@ # -# Cookbook Name:: ntp +# Cookbook:: ntp # Recipe:: default # -# Copyright 2010, OpenStreetMap Foundation. -# Copyright 2009, Opscode, Inc +# Copyright:: 2010, OpenStreetMap Foundation. +# Copyright:: 2009, Opscode, Inc # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # -# http://www.apache.org/licenses/LICENSE-2.0 +# https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, @@ -17,11 +17,12 @@ # See the License for the specific language governing permissions and # limitations under the License. -require "socket" +include_recipe "munin" -package "ntp" -package "ntpdate" -package "tzdata" +package %w[ + chrony + tzdata +] execute "dpkg-reconfigure-tzdata" do action :nothing @@ -30,40 +31,47 @@ execute "dpkg-reconfigure-tzdata" do group "root" end -file "/etc/timezone" do +link "/etc/localtime" do + to "/usr/share/zoneinfo/#{node[:ntp][:tz]}" owner "root" group "root" - mode 0o644 - content "#{node[:tz]}\n" notifies :run, "execute[dpkg-reconfigure-tzdata]", :immediately end -service "ntp" do - action [:enable, :start] - supports :status => true, :restart => true -end - -template "/etc/ntp.conf" do - source "ntp.conf.erb" +template "/etc/chrony/chrony.conf" do + source "chrony.conf.erb" owner "root" group "root" - mode 0o644 - notifies :restart, "service[ntp]" + mode "644" + notifies :restart, "service[chrony]" +end + +service "systemd-timesyncd" do + action [:stop, :disable] +end + +systemd_service "chrony-restart" do + service "chrony" + dropin "restart" + restart "on-failure" + notifies :restart, "service[chrony]" end -munin_plugins = %w(ntp_kernel_err ntp_kernel_pll_freq ntp_kernel_pll_off ntp_offset) +service "chrony" do + action [:enable, :start] +end -munin_plugin "ntp_kernel_err" -munin_plugin "ntp_kernel_pll_freq" -munin_plugin "ntp_kernel_pll_off" -munin_plugin "ntp_offset" +munin_plugin "chrony" -if File.directory?("/etc/munin/plugins") - Dir.new("/etc/munin/plugins").each do |plugin| - next unless plugin.match(/^ntp_/) && !munin_plugins.include?(plugin) +prometheus_exporter "chrony" do + port 9123 +end - munin_plugin plugin do - action :delete - end - end +# chrony occasionally marks all servers offline during a network outage. +# force online all sources during a chef run +execute "chronyc-online" do + command "/usr/bin/chronyc online" + user "root" + group "root" + ignore_failure true end