X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/3a327f56eac7ed2b5b696f432c4176b0d08fa2e4..0aaea8096fcdd565f0f1990a84ad68e9aeb90113:/cookbooks/sysctl/recipes/default.rb diff --git a/cookbooks/sysctl/recipes/default.rb b/cookbooks/sysctl/recipes/default.rb index b65b12a21..ae22a7b3b 100644 --- a/cookbooks/sysctl/recipes/default.rb +++ b/cookbooks/sysctl/recipes/default.rb @@ -1,8 +1,8 @@ # -# Cookbook Name:: sysctl +# Cookbook:: sysctl # Recipe:: default # -# Copyright 2010, Tom Hughes +# Copyright:: 2010, Tom Hughes # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -17,42 +17,35 @@ # limitations under the License. # -if node[:virtualization][:role] == "guest" && - node[:virtualization][:system] == "lxd" - file "/etc/sysctl.d/60-chef.conf" do - action :delete - end -else - package "procps" +file "/etc/sysctl.d/60-chef.conf" do + action :delete +end - directory "/etc/sysctl.d" do - owner "root" - group "root" - mode 0o755 - end +if node[:virtualization][:role] != "guest" || + (node[:virtualization][:system] != "lxc" && + node[:virtualization][:system] != "lxd") + keys = [] - execute "sysctl" do - action :nothing - command "/sbin/sysctl -p /etc/sysctl.d/60-chef.conf" - end + Dir.new("/etc/sysctl.d").each_entry do |file| + next unless file =~ /^99-chef-(.*)\.conf$/ - template "/etc/sysctl.d/60-chef.conf" do - source "chef.conf.erb" - owner "root" - group "root" - mode 0o644 - notifies :run, "execute[sysctl]" + keys.push(Regexp.last_match(1)) end node[:sysctl].each_value do |group| group[:parameters].each do |key, value| - sysctl_file = "/proc/sys/#{key.tr('.', '/')}" - - file sysctl_file do - content "#{value}\n" - atomic_update false - ignore_failure true + sysctl key do + value value + # comment group[:comment] end + + keys.delete(key) + end + end + + keys.each do |key| + sysctl key do + action :remove end end end