summaryrefslogtreecommitdiff
path: root/files/munin/puppet_
blob: 279f5ab60295837614c6485156de3337c6d32b78 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#!/usr/bin/env ruby

# returns the mem usage of a given process
def plist(psname)
  counter = 0
  %x{ps h -o rss,size,vsize,pcpu -u puppet}.each do |ps|
    rss,size,vsize,cpu = ps.split
    counter += 1
    puts "puppetmasterd_#{counter}.value #{rss}"

  end
  return
end

# reports how many clients compiled in the last 5 minutes
# repotrs how many unique clients compiled since the begining of the day
# report the average compilation time for all clients in the last 5 minutes.
def phaselog(logfile)
  count,avg,day_count_unique,day_count = 0 ,0 ,0, 0
  t = Time.now
        today = t.strftime("^%b ") + " ?" + t.day.to_s
  hour = today + t.strftime(" %H:")
  m = t.min.to_i
  last5m = ""
  6.times do |i|
    last5m += hour
    last5m += "0" if (m-i) < 10
    last5m += (m-i).to_s
    last5m += "|" unless i==5
  end
  hosts = Array.new
  regexp = ".* for (.*) in (.*) seconds"

  File.open(logfile).grep(/#{today}/).grep(/Compiled configuration|Compiled catalog/).each do |line|
    case line
      when /#{last5m}/ then
        if line =~ /#{regexp}/
          avg += $2.to_f
          count += 1
          unless hosts.include?($1)
            hosts << $1
          end
        end
      when /#{regexp}/ then
        day_count += 1
        unless hosts.include?($1)
          hosts << $1
          day_count_unique += 1
        end
    end
  end
  puts "avg_compile.value #{(avg / count).to_s[0..3]}" unless count == 0
  puts "last5m_count.value #{count}"
  puts "last24h_unique_count.value #{day_count_unique}"
end

sys_file = '/etc/default/puppetmaster'
sys_file = '/etc/sysconfig/puppetmaster' if !File.exists?(sys_file) && File.exists?('/etc/sysconfig/puppetmaster')
logfile = ENV['puppet_logfile'] || '/var/log/daemon.log'
facts_dir = ENV['facts_dir'] || '/var/lib/puppet/yaml/facts/'

case ARGV[0]
  when 'config'
    case $0
    when /puppetmaster_memory/
      puts "graph_title puppetmaster memory usage"
      puts "graph_vlabel memory"
      # find out how many mongrel process we have - if any
      File.open(sys_files) do |line|
        @pm_process = line.grep(/(PUPPETMASTERS|PUPPETMASTER_PORTS)/).to_s.split('=')[1].to_i
      end
      if @pm_process > 0
        @pm_process.times do |i|
          puts "puppetmasterd_#{i+1}.label puppetmasterd #{i+1}"
        end
      else
        puts "puppetmaster.label puppetmasterd"
      end
    when /puppet_clients/
      puts "graph_title puppet clients usage"
      puts "graph_vlabel clients"
      puts "known_clients.label Known Clients"
      puts "avg_compile.label Average configuration compile"
      puts "last5m_count.label Clients in the last 5 minutes"
      puts "last24h_unique_count.label unique clients in the last 24 hours"
    end
    puts "graph_category puppet"
    exit 0
  when 'autoconf'
    case $0
      when /puppet_mem/,/puppet_clients/
        if  File.exists?(sys_file) && File.exists?(logfile) && File.directory?(facts_dir)
          puts "yes"
        else
          puts "no"
        end
      else
        puts "no"
      exit 0
    end
  else
    plist("'ruby /usr/sbin/puppetmasterd'") if $0 =~ /puppet_mem$/
    if $0 =~ /puppet_clients$/
      puts "known_clients.value #{Dir.entries(facts_dir).size-2}"
      phaselog(logfile)
    end
end