DESCRIPTION

Manage sysctl via a sysctl LWRP.

Attributes

Name Value Description
default[:sysctl][:values] {} Hash Of Key Value pairs the attribute_driver recipe uses.
default[:sysctl][:config_file] rhel: "/etc/sysctl.conf" debian: "/etc/sysctl.d/99-chef.conf" The file to write values to.

Recipes

Name Description
attribute_driver.rb Reads attributes set in node[:sysctl][:values], and sets sysctl resources with the values
default.rb Simply sets up the resources needed to use the lwrp
library.rb Empty recipe if you want to avoid default, but still want to explicitly include (for whatever reason)

Sysctl LWRP

Attributes

Name Type Default Description
name String :name_attribute The key name. Defaults to the resource name i.e. sysctl "some.key"
value String, Fixnum, Integer The Value for this key
save boolean true save the setting back to the node data (default: false)

Actions

action default Description
:set yes Make sure the running state is set (default)
:write yes Write the config file (default)

Known Bugs

  • RHEL/CentOS 6 now have sysctl.d Directory, we should generate a config in this dir instead
  • only intended to be used on Linux

Example Usage

LWRP

Ensure running state, and write this key to sysctl.conf

sysctl "kernel.sysrq" do
   value 1
end

Check out [example/recipes/example.rb] 2 For more recipe examples.

ChefSpec Matchers

There are chefspec matchers in this cookbook to test your usage of the lwrp

set_sysctl

matcher for the set action

write_sysctl

matcher for the write action

Attributes

In a role attribute or override:

{
  "sysctl": {
    "values": {
     "net.ipv4.tcp_window_scaling": 0
    }
  }
}

Check out [example/attributes/example.rb] 1 For more attribute examples.

Author and License

Author Jesse Nelson spheromak@gmail.com

Copyright 2011-2013, Jesse Nelson

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

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.