mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-25 06:03:36 +03:00
Built-in FINALIZE action for the ActionManager. No thread is now started
for the ActionManager. Updated the examples git-svn-id: http://svn.opennebula.org/one/trunk@334 3034c82b-c49b-4eb3-8279-a7acafdc01c0
This commit is contained in:
parent
a8e3c441fa
commit
0357b87471
@ -64,14 +64,15 @@ class ActionManager
|
||||
# +threaded+ if true actions will be executed by default in a different
|
||||
# thread
|
||||
def initialize(concurrency=10, threaded=true)
|
||||
@finalize = false
|
||||
@actions = Hash.new
|
||||
@threaded = threaded
|
||||
@listener = nil
|
||||
|
||||
@concurrency = concurrency
|
||||
@action_queue = Array.new
|
||||
@running_actions = 0
|
||||
|
||||
@listener_thread = nil
|
||||
@threads_mutex = Mutex.new
|
||||
@threads_cond = ConditionVariable.new
|
||||
end
|
||||
@ -95,7 +96,16 @@ class ActionManager
|
||||
# +aname+ name of the action
|
||||
# +aargs+ arguments to call the action
|
||||
def trigger_action(aname,*aargs)
|
||||
|
||||
return if @finalize
|
||||
|
||||
@threads_mutex.synchronize {
|
||||
|
||||
if aname == "FINALIZE"
|
||||
@finalize = true
|
||||
@threads_cond.signal if @running_actions == 0
|
||||
return
|
||||
end
|
||||
|
||||
if !@actions.has_key?(aname)
|
||||
return
|
||||
@ -113,23 +123,19 @@ class ActionManager
|
||||
}
|
||||
end
|
||||
|
||||
def stop_listener
|
||||
@listener_thread.kill!
|
||||
end
|
||||
|
||||
def start_listener
|
||||
@listener_thread = Thread.new {
|
||||
while true
|
||||
@threads_mutex.synchronize {
|
||||
while ((@concurrency - @running_actions)==0) ||
|
||||
@action_queue.size==0
|
||||
@threads_cond.wait(@threads_mutex)
|
||||
end
|
||||
|
||||
while true
|
||||
@threads_mutex.synchronize {
|
||||
while ((@concurrency - @running_actions)==0) ||
|
||||
@action_queue.size==0
|
||||
@threads_cond.wait(@threads_mutex)
|
||||
|
||||
return if ( @finalize && @running_actions == 0)
|
||||
end
|
||||
|
||||
run_action
|
||||
}
|
||||
end
|
||||
}
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
@ -153,7 +159,6 @@ private
|
||||
action[:method].call(*action[:args])
|
||||
|
||||
@running_actions -= 1
|
||||
@threads_cond.signal
|
||||
end
|
||||
end
|
||||
end
|
||||
@ -171,9 +176,6 @@ if __FILE__ == $0
|
||||
@am.register_action("SLEEP",method("sleep_action"))
|
||||
# @am.register_action("SLEEP",Proc.new{|s,i| p s ; sleep(s)})
|
||||
@am.register_action("NOP",method("nop_action"))
|
||||
@am.register_action("FINALIZE",method("finalize_action"),false)
|
||||
|
||||
@am.start_listener
|
||||
end
|
||||
|
||||
def sleep_action(secs, id)
|
||||
@ -185,27 +187,24 @@ if __FILE__ == $0
|
||||
def nop_action
|
||||
p " - Just an action"
|
||||
end
|
||||
|
||||
def finalize_action
|
||||
p "Exiting..."
|
||||
@am.stop_listener
|
||||
p "Done!"
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
s = Sample.new
|
||||
|
||||
100.times {|n|
|
||||
100.times {|m|
|
||||
s.am.trigger_action("SLEEP",rand(3)+1,m+n)
|
||||
Thread.new {
|
||||
sleep 1
|
||||
100.times {|n|
|
||||
s.am.trigger_action("SLEEP",rand(3)+1,n)
|
||||
s.am.trigger_action("NOP")
|
||||
}
|
||||
|
||||
s.am.trigger_action("FINALIZE")
|
||||
|
||||
s.am.trigger_action("SLEEP",rand(3)+1,999)
|
||||
s.am.trigger_action("SLEEP",rand(3)+1,333)
|
||||
}
|
||||
|
||||
sleep 10
|
||||
|
||||
s.am.trigger_action("FINALIZE")
|
||||
|
||||
sleep 3600
|
||||
|
||||
s.am.start_listener
|
||||
end
|
||||
|
||||
|
@ -33,7 +33,6 @@ class OpenNebulaDriver
|
||||
@send_mutex=Mutex.new
|
||||
|
||||
@am = ActionManager.new(concurrency,threaded)
|
||||
@am.register_action("FINALIZE",method("stop_driver"),false)
|
||||
end
|
||||
|
||||
def send_message(*args)
|
||||
@ -53,17 +52,15 @@ class OpenNebulaDriver
|
||||
end
|
||||
|
||||
def start_driver
|
||||
loop_thread = Thread.new { loop }
|
||||
|
||||
@am.start_listener
|
||||
loop
|
||||
|
||||
loop_thread.kill!
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def stop_driver
|
||||
@am.stop_listener
|
||||
exit(0)
|
||||
end
|
||||
|
||||
def loop
|
||||
while true
|
||||
exit(-1) if STDIN.eof?
|
||||
@ -106,6 +103,4 @@ if __FILE__ == $0
|
||||
sd = SampleDriver.new
|
||||
sd.start_driver
|
||||
|
||||
gets
|
||||
|
||||
end
|
Loading…
x
Reference in New Issue
Block a user