Sha256: 248a078a9cc31c220a203487042e03679da48ecd55646e60b3ebf37a26b680ed

Contents?: true

Size: 1.18 KB

Versions: 21

Compression:

Stored size: 1.18 KB

Contents

require 'digest/md5'

Puppet::Parser::Functions::newfunction(:fqdn_rand, :arity => -2, :type => :rvalue, :doc =>
  "Usage: `fqdn_rand(MAX, [SEED])`. MAX is required and must be a positive
  integer; SEED is optional and may be any number or string.

  Generates a random Integer number greater than or equal to 0 and less than MAX,
  combining the `$fqdn` fact and the value of SEED for repeatable randomness.
  (That is, each node will get a different random number from this function, but
  a given node's result will be the same every time unless its hostname changes.)

  This function is usually used for spacing out runs of resource-intensive cron
  tasks that run on many nodes, which could cause a thundering herd or degrade
  other services if they all fire at once. Adding a SEED can be useful when you
  have more than one such task and need several unrelated random numbers per
  node. (For example, `fqdn_rand(30)`, `fqdn_rand(30, 'expensive job 1')`, and
  `fqdn_rand(30, 'expensive job 2')` will produce totally different numbers.)") do |args|
    max = args.shift.to_i
    seed = Digest::MD5.hexdigest([self['::fqdn'],args].join(':')).hex
    Puppet::Util.deterministic_rand_int(seed,max)
end

Version data entries

21 entries across 21 versions & 1 rubygems

Version Path
puppet-4.3.2 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.2-x86-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.2-x64-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.1 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.1-x86-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.1-x64-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.0 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.0-x86-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.3.0-x64-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.3 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.3-x86-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.3-x64-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.2 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.2-x86-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.2-x64-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.1 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.1-x86-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.1-x64-mingw32 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.0 lib/puppet/parser/functions/fqdn_rand.rb
puppet-4.2.0-x86-mingw32 lib/puppet/parser/functions/fqdn_rand.rb