Skip to content
This repository has been archived by the owner on Jun 11, 2019. It is now read-only.

example42/puppet-sysctl

Repository files navigation

Deprecation notice

This module was designed for Puppet versions 2 and 3. It should work also on Puppet 4 but doesn't use any of its features.

The current Puppet 3 compatible codebase is no longer actively maintained by example42.

Still, Pull Requests that fix bugs or introduce backwards compatible features will be accepted.

Puppet module: sysctl

This is a Puppet module for sysctl It provides only package installation and file configuration.

Based on Example42 layouts by Alessandro Franceschi / Lab42

Sysctl type and sysyctl::value define have been copied from Duritong's puppet-sysctl https://github.com/duritong/puppet-sysctl

Official site: http://www.example42.com

Official git repository: http://github.com/example42/puppet-sysctl

Released under the terms of Apache 2 License.

This module requires the presence of Example42 Puppi module in your modulepath.

USAGE

You can decide to manage sysctl with 2 alternative methods:

  • Manage the /etc/sysctl.conf file (and /etc/sysctl.d directory) with the (Example42 standard) source and termplate parameters
  • Manage single sysctl entries with the sysctl::value define
  • Use custom sources for /etc/sysctl.conf

      class { 'sysctl':
        source => [ "puppet:///modules/example42/sysctl/sysctl.conf-${hostname}" , "puppet:///modules/example42/sysctl/sysctl.conf" ], 
      }
    
  • Use custom source directory for the content of /etc/sysctl.d/

      class { 'sysctl':
        source_dir       => 'puppet:///modules/example42/sysctl/conf/',
        source_dir_purge => false, # Set to true to purge any existing file not present in $source_dir
      }
    
  • Use custom template for /etc/sysctl.conf . Note that template and source arguments are alternative.

      class { 'sysctl':
        template => 'example42/sysctl/sysctl.conf.erb',
      }
    
  • Manage atomically single sysctl entries (alternative to the source and template options):

      sysctl::value { "vm.nr_hugepages": value => "1583"}
    
  • Automatically include a custom subclass

      class { 'sysctl':
        my_class => 'example42::my_sysctl',
      }
    

Build Status