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:
parent
cb5397c8ca
commit
e4448510bf
@ -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
|
||||
|
Loading…
x
Reference in New Issue
Block a user