mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-26 10:03:37 +03:00
(cherry picked from commit 4e6b2d410c8a1f947223d358b45b706a7a2b0b25)
This commit is contained in:
parent
c3d0e70f34
commit
f41ed0cda2
@ -54,7 +54,7 @@ class HookManagerDriver < OpenNebulaDriver
|
||||
# --------------------------------------------------------------------------
|
||||
DEFAULT_CONF = {
|
||||
:concurrency => 15,
|
||||
:threaded => false,
|
||||
:threaded => true,
|
||||
:retries => 0,
|
||||
:publisher_port => 2101,
|
||||
:logger_port => 2102,
|
||||
@ -64,7 +64,6 @@ class HookManagerDriver < OpenNebulaDriver
|
||||
|
||||
def initialize(options)
|
||||
@options = DEFAULT_CONF.merge(options)
|
||||
@options[:concurrency] = 1 # Only on thread using the publisher socket
|
||||
|
||||
super('', @options)
|
||||
|
||||
@ -81,6 +80,9 @@ class HookManagerDriver < OpenNebulaDriver
|
||||
@replier = context.socket(ZMQ::REP)
|
||||
@replier.bind("tcp://#{@options[:bind]}:#{@options[:logger_port]}")
|
||||
|
||||
# Lock to sync access to @publisher
|
||||
@publisher_lock = Mutex.new
|
||||
|
||||
Thread.new do
|
||||
receiver_thread
|
||||
end
|
||||
@ -94,10 +96,7 @@ class HookManagerDriver < OpenNebulaDriver
|
||||
key(type, arg_xml).each do |key|
|
||||
m_key = "EVENT #{key}"
|
||||
|
||||
# Using envelopes for splitting key/val
|
||||
# http://zguide.zeromq.org/page:all#Pub-Sub-Message-Envelopes
|
||||
send_string(@publisher, m_key, ZMQ::SNDMORE)
|
||||
send_string(@publisher, arguments.flatten[0])
|
||||
publish_message(@publisher, m_key, arguments.flatten[0])
|
||||
end
|
||||
rescue StandardError => e
|
||||
log(0, "ERROR: #{e.message}")
|
||||
@ -114,8 +113,7 @@ class HookManagerDriver < OpenNebulaDriver
|
||||
m_key = 'RETRY'
|
||||
m_val = "#{command} #{params}"
|
||||
|
||||
send_string(@publisher, m_key, ZMQ::SNDMORE)
|
||||
send_string(@publisher, m_val)
|
||||
publish_message(@publisher, m_key, m_val)
|
||||
rescue StandardError => e
|
||||
log(0, "ERROR: #{e.message}")
|
||||
end
|
||||
@ -173,13 +171,15 @@ class HookManagerDriver < OpenNebulaDriver
|
||||
end
|
||||
end
|
||||
|
||||
def send_string(socket, content, flag = nil)
|
||||
def publish_message(socket, key, content)
|
||||
rc = 0
|
||||
|
||||
if flag.nil?
|
||||
rc = socket.send_string(content)
|
||||
else
|
||||
rc = socket.send_string(content, flag)
|
||||
# Make sure only one thread publish on the socket at a time
|
||||
@publisher_lock.synchronize do
|
||||
# Using envelopes for splitting key/content
|
||||
# http://zguide.zeromq.org/page:all#Pub-Sub-Message-Envelopes
|
||||
rc = socket.send_string(key, ZMQ::SNDMORE)
|
||||
rc = socket.send_string(content) unless rc < 0
|
||||
end
|
||||
|
||||
return unless rc < 0
|
||||
|
Loading…
x
Reference in New Issue
Block a user