mirror of
https://github.com/puppetlabs/vmpooler.git
synced 2026-01-26 10:08:40 -05:00
This commit updates vmpooler graphite stats behavior when a connection cannot be opened to the graphite server to warn instead of allowing the full backtrace to be output to stderr. Without this change a backtrace is output to stderr when a graphite connection fails.
44 lines
1.1 KiB
Ruby
44 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rubygems' unless defined?(Gem)
|
|
|
|
module Vmpooler
|
|
class Graphite
|
|
attr_reader :server, :port, :prefix
|
|
|
|
def initialize(params = {})
|
|
raise ArgumentError, "Graphite server is required. Config: #{params.inspect}" if params['server'].nil? || params['server'].empty?
|
|
|
|
@server = params['server']
|
|
@port = params['port'] || 2003
|
|
@prefix = params['prefix'] || 'vmpooler'
|
|
end
|
|
|
|
def increment(label)
|
|
log label, 1
|
|
end
|
|
|
|
def gauge(label, value)
|
|
log label, value
|
|
end
|
|
|
|
def timing(label, duration)
|
|
log label, duration
|
|
end
|
|
|
|
def log(path, value)
|
|
Thread.new do
|
|
socket = TCPSocket.new(server, port)
|
|
begin
|
|
socket.puts "#{prefix}.#{path} #{value} #{Time.now.to_i}"
|
|
ensure
|
|
socket.close
|
|
end
|
|
end
|
|
rescue Errno::EADDRNOTAVAIL => e
|
|
warn "Could not assign address to graphite server #{server}: #{e}"
|
|
rescue StandardError => e
|
|
warn "Failure logging #{path} to graphite server [#{server}:#{port}]: #{e}"
|
|
end
|
|
end
|
|
end
|