1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-27 14:03:40 +03:00

Feature #1678: Simplify the collectd-client.rb algorithm by adding

a random sleep at the beginning.
This commit is contained in:
Jaime Melis 2013-11-05 16:13:54 +01:00
parent cb5397c8ca
commit e4448510bf

View File

@ -23,20 +23,14 @@ DIRNAME = File.dirname(__FILE__)
REMOTE_DIR_UPDATE = File.join(DIRNAME, '../../.update')
class CollectdClient
SLEEP = 1
def initialize(hypervisor, number, host, port, probes_args, cycle)
def initialize(hypervisor, number, host, port, probes_args,
monitor_push_period)
# Arguments
@hypervisor = hypervisor
@number = number.to_i
@host = host
@port = port
@cycle = cycle.to_i
@cycle = 20 if @cycle == 0
# Monitorization slot
@my_slot = @number % @cycle
@monitor_push_period = monitor_push_period
# Probes
run_probes_cmd = File.join(DIRNAME, '..', "run_probes")
@ -60,58 +54,24 @@ class CollectdClient
@s.send("MONITOR SUCCESS #{@number} #{data}\n", 0, @host, @port)
end
def do_send?(current, last_send)
current_cycle = current[0]
current_slot = current[1]
last_cycle = last_send[0]
last_slot = last_send[1]
if last_slot < @my_slot
min_cycle = last_cycle
else
min_cycle = last_cycle + 1
end
if current_cycle > min_cycle
return true
elsif current_cycle < min_cycle
return false
else
return current_slot >= @my_slot
end
end
def monitor
initial = true
data = run_probes
last_send = nil
loop do
# Stop the execution if we receive the update signal
exit 0 if stop?
t = Time.now.to_i
current_cycle = t / @cycle
current_slot = t % @cycle
current = [current_cycle, current_slot]
if initial
last_send = current
initial = false
end
if do_send?(current, last_send)
send data
last_send = current
# Collect the Data
ts = Time.now
data = run_probes
end
sleep SLEEP
run_probes_time = (Time.now - ts).to_i
# Send the Data
send data
# Sleep during the Cycle
sleep_time = @monitor_push_period - run_probes_time
sleep_time = 0 if sleep_time < 0
sleep sleep_time
end
end
@ -129,11 +89,18 @@ end
hypervisor = ARGV[0]
port = ARGV[2]
cycle = ARGV[3]
monitor_push_period = ARGV[3].to_i
number = ARGV[4]
monitor_push_period = 20 if monitor_push_period == 0
host = ENV['SSH_CLIENT'].split.first
probes_args= ARGV[1..-1].join(" ")
client = CollectdClient.new(hypervisor, number, host, port, probes_args, cycle)
# Add a random sleep before the first send
sleep rand monitor_push_period
# Start push monitorization
client = CollectdClient.new(hypervisor, number, host, port, probes_args,
monitor_push_period)
client.monitor