update to dashboard repo, update to pupppet-run

This commit is contained in:
do
2013-02-02 20:26:53 +01:00
parent aa3fa40310
commit aaea443943
2 changed files with 186 additions and 218 deletions

View File

@@ -1,234 +1,201 @@
# $Id: init.pp 4425 2011-06-17 11:42:17Z uwaechte $ # $Id: init.pp 4425 2011-06-17 11:42:17Z uwaechte $
class puppet ($ensure = "present", class puppet (
$norunifloggedin = false, $ensure = "present",
$daemonize = true, $norunifloggedin = false,
$run_hour = "*/1", $daemonize = true,
$run_minute = "10", $run_hour = "*/1",
$run_if_ipmatch = "") { $run_minute = "10",
$puppet_service = $kernel ? { $run_if_ipmatch = "") {
"Darwin" => "org.macports.puppet", $puppet_service = $kernel ? {
"FreeBSD" => "puppetd", "Darwin" => "org.macports.puppet",
default => "puppet" "FreeBSD" => "puppetd",
} default => "puppet"
$factpath = "/var/lib/puppet/lib/facter" }
case $kernel { $factpath = "/var/lib/puppet/lib/facter"
"Linux" : {
$puppetpkgs = ["puppet", "puppet-common"]
Package {
provider => "apt"
}
#Package["puppet-common"]{ before => Package["puppet"] }
} case $kernel {
default : { "Linux" : {
$puppetpkgs = "puppet" $puppetpkgs = ["puppet", "puppet-common"]
}
Package {
provider => "apt" }
} }
$puppet_linuxversion_real = $PUPPET_VERSION_LINUX ? { default : {
"" => "latest", $puppetpkgs = "puppet"
default => $PUPPET_VERSION_LINUX,
} }
# case $kernel { }
# "Linux": { $puppet_linuxversion_real = $PUPPET_VERSION_LINUX ? {
# exec{"apt-get install -y puppet=$PUPPET_VERSION_LINUX puppet-common=${PUPPET_VERSION_LINUX}": "" => "latest",
# onlyif => "apt-show-versions -a puppet |tail -1 |grep -q upgradeable", default => $PUPPET_VERSION_LINUX,
# } }
# }
# default: { package { $puppetpkgs:
package { ensure => $ensure ? {
$puppetpkgs : "present" => $kernel ? {
ensure => $ensure ? { "Linux" => $puppet_linuxversion_real,
"present" => $kernel ? {
"Linux" => $puppet_linuxversion_real,
default => $ensure,
}
},
notify => Service["${puppet_service}"],
}
# }
# }
package {
["facter"] :
ensure => "${ensure}",
}
service {
"${puppet_service}" :
hasstatus => true,
enable => "${daemonize}",
ensure => "${daemonize}",
}
$cron_real = $daemonize ? {
false => "present",
true => "absent",
default => $ensure, default => $ensure,
} } },
notice("${fqdn} PUPPET-CRON: cron_real: ${cron_real}, daemonize: ${daemonize}, running: ${service_running}") notify => Service["${puppet_service}"],
cron { }
puppetrun :
command => "/usr/local/sbin/puppetd_run.sh",
user => root,
minute => $run_minute,
hour => $run_hour,
ensure => "${cron_real}",
}
$maxsleep = 6400
file {
"/usr/local/sbin/puppetd_run.sh" :
content => template("puppet/puppetd_run.sh.erb"),
mode => 0700,
alias => "puppetd_run.sh",
ensure => "${ensure}",
}
case $kernel {
"Darwin" : {
file {
"/Library/LaunchDaemons/org.macports.puppet.plist" :
source =>
"puppet:///modules/puppet/org.macports.puppet.plist",
before => Service["${puppet_service}"],
}
file {
"/opt/local/lib/ruby/site_ruby/1.8/puppet/provider/package/appdmg.rb" :
ensure => "absent",
}
}
"Linux" : {
replace {
"enable_puppet" :
file => "/etc/default/puppet",
pattern => "START=no",
replacement => "START=yes",
before => Service["${puppet_service}"],
}
monit::process {
"puppet" :
start => "/etc/init.d/puppet start",
stop => "/etc/init.d/puppet stop",
pidfile => "/var/run/puppet/agent.pid",
additional =>
"if totalmem > 400 Mb for 10 cycles then RESTART",
ensure => $daemonize ? {
"true" => "present",
default => "absent",
},
}
}
}
$puppet_user = $operatingsystem ? {
"Darwin" => $adm,
default => "puppet",
}
$puppet_group = $operatingsystem ? {
"Darwin" => "wheel",
default => "puppet",
}
#"FreeBSD" => "/usr/local/etc/puppet/puppet.conf",
$puppetconf = $operatingsystem ? {
default => "/etc/puppet/puppet.conf",
}
file {
$puppetconf :
content => template("puppet/puppet.conf.erb"),
mode => 0644,
owner => $puppet_user,
ensure => "${ensure}",
# require => [ Package["puppet"] ],
}
#add facter variable to custom facts. package { ["facter"]: ensure => "${ensure}", }
file {
"/etc/profile.d/puppet.sh" : service { "${puppet_service}":
content => "export FACTERLIB=\"${factpath}\"\n", hasstatus => true,
ensure => $ensure, enable => "${daemonize}",
ensure => "${daemonize}",
}
$cron_real = $daemonize ? {
false => "present",
true => "absent",
default => $ensure,
}
notice("${fqdn} PUPPET-CRON: cron_real: ${cron_real}, daemonize: ${daemonize}, running: ${service_running}")
cron { puppetrun:
command => "/usr/local/sbin/puppetd_run.sh",
user => root,
minute => $run_minute,
hour => $run_hour,
ensure => "${cron_real}",
}
$maxsleep = 6400
file { "/usr/local/sbin/puppetd_run.sh":
content => template("puppet/puppetd_run.sh.erb"),
mode => 0700,
alias => "puppetd_run.sh",
ensure => "${ensure}",
}
case $kernel {
"Darwin" : {
file { "/Library/LaunchDaemons/org.macports.puppet.plist":
source => "puppet:///modules/puppet/org.macports.puppet.plist",
before => Service["${puppet_service}"],
}
file { "/opt/local/lib/ruby/site_ruby/1.8/puppet/provider/package/appdmg.rb": ensure => "absent", }
} }
"Linux" : {
replace { "enable_puppet":
file => "/etc/default/puppet",
pattern => "START=no",
replacement => "START=yes",
before => Service["${puppet_service}"],
}
monit::process { "puppet":
start => "/etc/init.d/puppet start",
stop => "/etc/init.d/puppet stop",
pidfile => "/var/run/puppet/agent.pid",
additional => "if totalmem > 400 Mb for 10 cycles then RESTART",
ensure => $daemonize ? {
"true" => "present",
default => "absent",
},
}
}
}
$puppet_user = $operatingsystem ? {
"Darwin" => $adm,
default => "puppet",
}
$puppet_group = $operatingsystem ? {
"Darwin" => "wheel",
default => "puppet",
}
# "FreeBSD" => "/usr/local/etc/puppet/puppet.conf",
$puppetconf = $operatingsystem ? {
default => "/etc/puppet/puppet.conf",
}
file { $puppetconf:
content => template("puppet/puppet.conf.erb"),
mode => 0644,
owner => $puppet_user,
ensure => "${ensure}",
# require => [ Package["puppet"] ],
}
# add facter variable to custom facts.
file { "/etc/profile.d/puppet.sh":
content => "export FACTERLIB=\"${factpath}\"\n",
ensure => $ensure,
}
} }
@@puppet::puppetmaster::privatedir {
$fqdn : @@puppet::puppetmaster::privatedir { $fqdn: l_fqdn => generate('/usr/bin/env', 'perl', '-e', '$_=shift;tr/[A-Z]/[a-z]/;print $_',
l_fqdn => generate('/usr/bin/env', 'perl', '-e', "$fqdn") }
'$_=shift;tr/[A-Z]/[a-z]/;print $_', "$fqdn")
}
class puppet::puppet-dashboard ($ensure = "present") { class puppet::puppet-dashboard ($ensure = "present") {
package { package { ["libjson-ruby", "puppet-dashboard"]:
["libjson-ruby", "puppet-dashboard"] : ensure => $ensure,
ensure => $ensure, require => Apt::Repository["puppet-dashboard"],
require => Apt::Repository["puppet-dashboard"], }
}
apt::repository { apt::repository { "puppet-dashboard":
"puppet-dashboard" : key => "8347A27F",
key => "8347A27F", repository => "deb http://apt.puppetlabs.com ${lsbdistcodename} main\n",
repository => ensure => $ensure,
"deb http://apt.puppetlabs.com/ubuntu lucid main\ndeb-src http://apt.puppetlabs.com/ubuntu lucid main\n", }
ensure => $ensure,
} cron { "purge-reports":
cron { command => "cd /usr/share/puppet-dashboard && rake RAILS_ENV=production reports:prune upto=14 unit=day",
"purge-reports" : user => "www-data",
command => hour => "23",
"cd /usr/share/puppet-dashboard && rake RAILS_ENV=production reports:prune upto=14 unit=day", minute => "2",
user => "www-data", monthday => "*/14",
hour => "23", ensure => $ensure,
minute => "2", }
monthday => "*/14",
ensure => $ensure, cron { "purge-optimizedb":
} command => "cd /usr/share/puppet-dashboard && rake RAILS_ENV=production db:raw:optimize",
cron { user => "www-data",
"purge-optimizedb" : hour => "23",
command => minute => "20",
"cd /usr/share/puppet-dashboard && rake RAILS_ENV=production db:raw:optimize", monthday => "*/10",
user => "www-data", ensure => $ensure,
hour => "23", }
minute => "20",
monthday => "*/10",
ensure => $ensure,
}
} }
class puppet::puppetmaster ($ensure = "present",
$puppetqd = true) { class puppet::puppetmaster ($ensure = "present", $puppetqd = false) {
if $puppetqd { if $puppetqd {
class { class { "activemq": ensure => $ensure }
"activemq" :
ensure => $ensure package { "libnet-arp-perl": ensure => $ensure }
}
package { service { "stompserver":
"libnet-arp-perl" : ensure => false,
ensure => $ensure enable => false,
} before => Class["activemq"],
service {
"stompserver" :
ensure => false,
enable => false,
before => Class["activemq"],
}
service {
"puppetqd" :
ensure => running,
pattern => "puppet queue queue",
enable => true,
}
}
Ganglia::Gmetric::Cron {
source => "puppet/ganglia",
ensure => "${ensure}",
}
ganglia::gmetric::cron {
"puppetmaster.rb" :
runwhen => "5",
}
ganglia::gmetric::cron {
"puppetmaster_compiletime.rb" :
runwhen => "60",
} }
### remove disk reports from time to time service { "puppetqd":
tidy { ensure => running,
"${puppet_vardir}/reports" : pattern => "puppet queue queue",
age => "1d", enable => true,
recurse => true,
backup => false,
} }
}
# create [private] directories Ganglia::Gmetric::Cron {
# file { $puppet_privdir: ensure => directory } source => "puppet/ganglia",
# Puppet::Puppetmaster::Privatedir <<| |>> ensure => "${ensure}",
}
ganglia::gmetric::cron { "puppetmaster.rb": runwhen => "5", }
ganglia::gmetric::cron { "puppetmaster_compiletime.rb": runwhen => "60", }
# ## remove disk reports from time to time
tidy { "${puppet_vardir}/reports":
age => "1d",
recurse => true,
backup => false,
}
# create [private] directories
# file { $puppet_privdir: ensure => directory }
# Puppet::Puppetmaster::Privatedir <<| |>>
} }
import "defines/*.pp" import "defines/*.pp"

View File

@@ -12,8 +12,9 @@
export FACTERLIB="<%= scope.lookupvar("factpath") %>" export FACTERLIB="<%= scope.lookupvar("factpath") %>"
PATH="/opt/local/bin:/opt/local/sbin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" PATH="/opt/local/bin:/opt/local/sbin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
PUPPET=$(which puppetd) PUPPET=$(which puppet)
[[ -e ${PUPPET} ]] || exit 1 [[ -e ${PUPPET} ]] || exit 1
PUPPET="${PUPPET} agent"
<% if run_if_ipmatch != "" -%> <% if run_if_ipmatch != "" -%>
ISUNIIP=$(ifconfig |grep -c -e "<%= run_if_ipmatch %>") ISUNIIP=$(ifconfig |grep -c -e "<%= run_if_ipmatch %>")
<% else -%> <% else -%>