python 监听salt job状态,并任务数据推送到redis中的方法
程序员文章站
2022-05-25 19:37:52
salt分发后,主动将已完成的任务数据推送到redis中,使用redis的生产者模式,进行消息传送
#coding=utf-8
import fnmatch,j...
salt分发后,主动将已完成的任务数据推送到redis中,使用redis的生产者模式,进行消息传送
#coding=utf-8 import fnmatch,json,logging import salt.config import salt.utils.event from salt.utils.redis import redispool import sys,os,datetime,random import multiprocessing,threading from joi.utils.gobsapi import postweb logger = logging.getlogger(__name__) opts = salt.config.client_config('/data/salt/saltstack/etc/salt/master') r_conn = redispool(opts.get('redis_db')).getconn() lock = threading.lock() class redisqueuedaemon(object): ''' redis 队列监听器 ''' def __init__(self,r_conn): self.r_conn = r_conn #redis 连接实例 self.task_queue = 'task:prod:queue' #任务消息队列 def listen_task(self): ''' 监听主函数 ''' while true: queue_item = self.r_conn.blpop(self.task_queue,0)[1] print "queue get",queue_item #self.run_task(queue_item) t = threading.thread(target=self.run_task,args=(queue_item,)) t.start() def run_task(self,info): ''' 执行操作函数 ''' lock.acquire() info = json.loads(info) if info['type'] == 'pushtaskdata': task_data = self.gettaskdata(info['jid']) task_data = json.loads(task_data) if task_data else [] logger.info('获取缓存数据:%s' % task_data) if task_data: if self.sendtaskdata2bs(task_data): task_data = [] self.settaskdata(info['jid'], task_data) elif info['type'] == 'settaskstate': self.settaskstate(info['jid'],info['state'],info['message']) elif info['type'] == 'settaskdata': self.settaskdata(info['jid'], info['data']) lock.release() def gettaskdata(self,jid): return self.r_conn.hget('task:'+jid,'data') def settaskdata(self,jid,data): self.r_conn.hset('task:'+jid,'data',json.dumps(data)) def sendtaskdata2bs(self,task_data): logger.info('发送任务数据到后端...') logger.info(task_data) if task_data: p = postweb('/jgapi/verify',task_data,'pushflowtaskdata') result = p.postres() print result if result['code']: logger.info('发送成功!') return true else: logger.error('发送失败!') return false else: return true def settaskstate(self,jid,state,message=''): logger.info('到后端设置任务【%s】状态' % str(jid)) p = postweb('/jgapi/verify',{'code':jid,'state':'success','message':message},'settaskstate') result = p.postres() if result['code']: logger.info('设置任务【%s】状态成功!' % str(jid)) return true,result else: logger.error('设置任务【%s】状态失败!' % str(jid)) return result def salt_job_listener(): ''' salt job 监听器 ''' sevent = salt.utils.event.get_event( 'master', sock_dir=opts['sock_dir'], transport=opts['transport'], opts=opts) while true: ret = sevent.get_event(full=true) if ret is none: continue if fnmatch.fnmatch(ret['tag'], 'salt/job/*/ret/*'): task_key = 'task:'+ret['data']['jid'] task_state = r_conn.hget(task_key,'state') task_data = r_conn.hget(task_key,'data') if task_state: jid_data = { 'code':ret['data']['jid'], 'project_id':settings.salt_master_opts['project_id'], 'serverip':ret['data']['id'], 'returns':ret['data']['return'], 'name':ret['data']['id'], 'state':'success' if ret['data']['success'] else 'failed', } task_data = json.loads(task_data) if task_data else [] task_data.append(jid_data) logger.info("新增数据:%s" % json.dumps(task_data)) r_conn.lpush('task:prod:queue',json.dumps({'type':'settaskdata','jid':ret['data']['jid'],'data':task_data})) #r_conn.hset(task_key,'data',json.dumps(task_data)) if task_state == 'running': if len(task_data)>=1: logger.info('新增消息到队列:pushtaskdata') r_conn.lpush('task:prod:queue',json.dumps({'jid':ret['data']['jid'],'type':'pushtaskdata'})) else: logger.info('任务{0}完成,发送剩下的数据到后端...'.format(task_key)) logger.info('新增消息到队列:pushtaskdata') r_conn.lpush('task:prod:queue',json.dumps({'jid':ret['data']['jid'],'type':'pushtaskdata'})) print datetime.datetime.now() def run(): print 'start redis product queue listerner...' logger.info('start redis product queue listerner...') multiprocessing.process(target=redisqueuedaemon(r_conn).listen_task,args=()).start() print 'start salt job listerner...' logger.info('start salt job listerner...') multiprocessing.process(target=salt_job_listener,args=()).start() ''' p=multiprocessing.pool(2) print 'start redis product queue listerner...' p.apply_async(redis_queue_listenr,()) print 'start salt job listerner...' p.apply_async(salt_job_listener,()) p.close() p.join() '''
以上这篇python 监听salt job状态,并任务数据推送到redis中的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
上一篇: python实现创建新列表和新字典,并使元素及键值对全部变成小写
下一篇: BOM