本文整理匯總了Python中Ganga.Core.GangaThread.GangaThread.stop方法的典型用法代碼示例。如果您正苦於以下問題:Python GangaThread.stop方法的具體用法?Python GangaThread.stop怎麽用?Python GangaThread.stop使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Ganga.Core.GangaThread.GangaThread
的用法示例。
在下文中一共展示了GangaThread.stop方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: TaskRegistry
# 需要導入模塊: from Ganga.Core.GangaThread import GangaThread [as 別名]
# 或者: from Ganga.Core.GangaThread.GangaThread import stop [as 別名]
class TaskRegistry(Registry):
def __init__(self, name, doc, dirty_flush_counter=10, update_index_time=30):
super(TaskRegistry, self).__init__( name, doc, dirty_flush_counter=dirty_flush_counter, update_index_time=update_index_time )
self._main_thread = None
self.stored_slice = TaskRegistrySlice(self.name)
self.stored_slice.objects = self
self.stored_proxy = TaskRegistrySliceProxy(self.stored_slice)
def getSlice(self):
return self.stored_slice
def getProxy(self):
return self.stored_proxy
def getIndexCache(self, obj):
if obj._data is None:
raise Exception("Currently don't support Index Caching")
cached_values = ['status', 'id', 'name']
c = {}
for cv in cached_values:
if cv in obj._data:
c[cv] = getattr(obj, cv)
this_slice = TaskRegistrySlice("tmp")
for dpv in this_slice._display_columns:
c["display:" + dpv] = this_slice._get_display_value(obj, dpv)
return c
def _thread_main(self):
""" This is an internal function; the main loop of the background thread """
from Ganga.Core.GangaRepository import getRegistry
while getRegistry("jobs").hasStarted() is not True:
time.sleep(0.1)
if self._main_thread is None or self._main_thread.should_stop():
return
while True:
from Ganga.Core import monitoring_component
if (not monitoring_component is None and monitoring_component.enabled) or config['ForceTaskMonitoring']:
break
time.sleep(0.1)
if self._main_thread is None or self._main_thread.should_stop():
return
# setup the tasks - THIS IS INCOMPATIBLE WITH CONCURRENCY
# and must go away soon
for tid in self.ids():
try:
self[tid].startup()
except Exception as err:
logger.error("Unknown/Unexpected Error in starting up tasks main loop")
logger.error("Exiting: err=%s" % str(err))
return
logger.debug("Entering main loop")
# Main loop
while self._main_thread is not None and not self._main_thread.should_stop():
# If monitoring is enabled (or forced for Tasks) loop over each one and update
if (config['ForceTaskMonitoring'] or monitoring_component.enabled) and not config['disableTaskMon']:
for tid in self.ids():
logger.debug("Running over tid: %s" % str(tid))
try:
p = self[tid]
p.update()
except Exception as x:
logger.error(
"Exception occurred in task monitoring loop: %s %s\nThe offending task was paused." % (x.__class__, x))
type_, value_, traceback_ = sys.exc_info()
logger.error("Full traceback:\n %s" % ' '.join(
traceback.format_exception(type_, value_, traceback_)))
p.pause()
if self._main_thread.should_stop():
break
if self._main_thread.should_stop():
break
logger.debug("TaskRegistry Sleeping for: %s seconds" % str(config['TaskLoopFrequency']))
# Sleep interruptible for 10 seconds
for i in range(0, int(config['TaskLoopFrequency'] * 100)):
if self._main_thread.should_stop():
break
time.sleep(0.01)
def startup(self):
""" Start a background thread that periodically run()s"""
super(TaskRegistry, self).startup()
from Ganga.Core.GangaThread import GangaThread
self._main_thread = GangaThread(name="GangaTasks", target=self._thread_main)
self._main_thread.start()
#.........這裏部分代碼省略.........
示例2: TaskRegistry
# 需要導入模塊: from Ganga.Core.GangaThread import GangaThread [as 別名]
# 或者: from Ganga.Core.GangaThread.GangaThread import stop [as 別名]
class TaskRegistry(Registry):
def __init__(self, name, doc, dirty_flush_counter=10, update_index_time=30):
super(TaskRegistry, self).__init__( name, doc, dirty_flush_counter=10, update_index_time=30 )
self._main_thread = None
def getProxy(self):
this_slice = TaskRegistrySlice(self.name)
this_slice.objects = self
return TaskRegistrySliceProxy(this_slice)
def getIndexCache(self, obj):
if obj.getNodeData() is None:
raise Exception("Currently don't support Index Caching")
cached_values = ['status', 'id', 'name']
c = {}
for cv in cached_values:
if cv in obj.getNodeData():
c[cv] = obj.getNodeAttribute(cv)
this_slice = TaskRegistrySlice("tmp")
for dpv in this_slice._display_columns:
c["display:" + dpv] = this_slice._get_display_value(obj, dpv)
return c
def _thread_main(self):
""" This is an internal function; the main loop of the background thread """
# Add runtime handlers for all the taskified applications, since now
# all the backends are loaded
from Ganga.GPIDev.Adapters.ApplicationRuntimeHandlers import allHandlers
from .TaskApplication import handler_map
for basename, name in handler_map:
for backend in allHandlers.getAllBackends(basename):
allHandlers.add(
name, backend, allHandlers.get(basename, backend))
from Ganga.Core.GangaRepository import getRegistry
while getRegistry("jobs").hasStarted() is not True:
time.sleep(0.1)
if self._main_thread is None or self._main_thread.should_stop():
return
while True:
from Ganga.Core import monitoring_component
if (not monitoring_component is None and monitoring_component.enabled) or config['ForceTaskMonitoring']:
break
time.sleep(0.1)
if self._main_thread is None or self._main_thread.should_stop():
return
# setup the tasks - THIS IS INCOMPATIBLE WITH CONCURRENCY
# and must go away soon
for tid in self.ids():
try:
self[tid]._getWriteAccess()
self[tid].startup()
except RegistryError:
continue
except Exception as err:
logger.error("Unknown/Unexpected Error in starting up tasks main loop")
logger.error("Exiting: err=%s" % str(err))
return
logger.debug("Entering main loop")
# Main loop
while self._main_thread is not None and not self._main_thread.should_stop():
# For each task try to run it
if config['ForceTaskMonitoring'] or monitoring_component.enabled:
for tid in self.ids():
logger.debug("Running over tid: %s" % str(tid))
try:
from Ganga.GPIDev.Lib.Tasks import ITask
if isType(self[tid], ITask):
# for new ITasks, always need write access
self[tid]._getWriteAccess()
p = self[tid]
else:
if self[tid].status in ["running", "running/pause"]:
self[tid]._getWriteAccess()
p = self[tid]
elif self[tid].status is 'completed' and (self[tid].n_status('ready') or self[tid].n_status('running')):
self[tid].updateStatus()
continue
else:
continue
except RegistryError:
# could not acquire lock
continue
if self._main_thread.should_stop():
break
try:
from Ganga.GPIDev.Lib.Tasks import ITask
if isType(self[tid], ITask):
#.........這裏部分代碼省略.........
示例3: while
# 需要導入模塊: from Ganga.Core.GangaThread import GangaThread [as 別名]
# 或者: from Ganga.Core.GangaThread.GangaThread import stop [as 別名]
while (test_active() and not test_paused()):
test = Test.objects.get(pk=testid)
# logger.info('HC Copy Thread: TOP OF MAIN LOOP')
for job in jobs:
if not test_active() or test_paused() or ct.should_stop():
break
copyJob(job)
test_sleep(10)
logger.info('Main thread exited.')
else:
logger.warning('No jobs to monitor. Exiting now.')
#Stop thread.
ct.stop()
paused = test_paused()
if not paused:
test.state = 'completed'
test.endtime = datetime.now()
test.save()
logger.info('Test state updated to %s'%(test.state))
logger.info('Disconnected from DB')
if not paused:
try:
logger.info('Killing leftover "submitted" jobs')
jobs.select(status='submitted').kill()
示例4: process_subjob
# 需要導入模塊: from Ganga.Core.GangaThread import GangaThread [as 別名]
# 或者: from Ganga.Core.GangaThread.GangaThread import stop [as 別名]
for subjob in job.subjobs:
try:
process_subjob(job,subjob)
except:
raise
logger.warning('Exception in process_subjob:')
logger.warning(sys.exc_info()[0])
logger.warning(sys.exc_info()[1])
if test_paused():
break
test_sleep(30)
else:
logger.warning('No jobs to monitor. Exiting now.')
#Stop plotting and summarizing thread.
pt.stop()
ct.stop()
paused = test_paused()
if not paused:
test.state = 'completed'
test.endtime = datetime.now()
test.save()
logger.info('Test state updated to %s'%(test.state))
logger.info('Disconnected from DB')
if not paused:
try:
logger.info('Killing leftover "submitted" jobs')
示例5: process_subjob
# 需要導入模塊: from Ganga.Core.GangaThread import GangaThread [as 別名]
# 或者: from Ganga.Core.GangaThread.GangaThread import stop [as 別名]
process_subjob(job, subjob)
except:
logger.warning('Exception in process_subjob:')
logger.warning(sys.exc_info()[0])
logger.warning(sys.exc_info()[1])
if test_paused():
break
test_sleep(20)
print '.',
else:
noJobs = True
logger.warning('No jobs to monitor. Exiting now.')
#Stop plotting and summarizing thread.
pt.stop()
paused = test_paused()
if not paused:
if noJobs:
test.state = 'error'
else:
test.state = "completed"
test.endtime = datetime.now()
test.save()
logger.info('Test state updated to %s' % (test.state))
logger.info('Disconnected from DB')
if not paused: