啥也不说了,先贴代码:
def monitor(client):
run_heartbeat = client.run.heartbeat
etc_rpc = client.etc.rpc
document = etc_rpc.find_one({'server':'taskmanager'})
rpc = document['host'] + ':' + document['port']
if process_ok('taskmanager'):
run_heartbeat.update({'process':'taskmanager','rpc':rpc},{'$set':{'selftesttime':datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S'),'selftest':'ok'}})
logging.info("update : selftest is 'ok'")
print "update : run_heartbeat.taskmanager.selftest is 'ok'"
else:
run_heartbeat.update({'process':'taskmanager','rpc':rpc},{'$set':{'selftesttime':datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S'),'selftest':'process error'}})
logging.info("update : selftest is 'process error'")
print "update : run_heartbeat.taskmanager.selftest is 'process error'"
if __name__ == "__main__":
print "TaskMonitor beginning......"
sched = Scheduler()
sched.daemonic = False
sched.add_interval_job(monitor,seconds=int(tasktime),args=[client])
sched.start()
功能:每隔tasktime秒就运行一次monitor函数
期望结果:在运行过程中通过CTRL+C停止
求大神解决办法!