Skip to content

Wrapper for running the puppet agent from cron

License

Notifications You must be signed in to change notification settings

ploperations/puppet-runner

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

61 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A wrapper for running the puppet agent

Our workflow is to develop changes in feature branches, which become environments. Once those branches are merged, they are deleted from the repo and thus the environment is deleted.

This wrapper reverts to production if the configured environment is invalid.

This does not directly use the gem or directly modify the puppet configuration file. Everything goes through the puppet executable.

This can run on any platforms Go can target. Most relevant to us are Linux, macOS, Solaris, and Windows.

Usage

Linux, macOS, Solaris x86

Assuming you have installed this to /usr/local/bin/puppet-runner, create a cron job similar to the one below. The reason for the path information is so that facts will be resolved correctly.

PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/opt/puppetlabs/bin
0,30 * * * * /usr/local/bin/puppet-runner

If there is an error, or if the environment is reset to production, the wrapper will write to stdout, and thus generate an email.

Windows

Configure a scheduled task to run puppet-runner every thirty minutes.

Building

  • See go.mod for a known working version of Go to use with this application.
  • See build.sh for how the application is built. This script is designed to work both locally and in CI.

About

Wrapper for running the puppet agent from cron

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •