python守护多线程_Python守护进程(多线程开发)

#!/usr/bin/python

importsys,time,json,loggingimportQueue, threading, datetimefrom lib.base.daemon importDaemonfrom lib.queue.httpsqs.HttpsqsClient importHttpsqsClientfrom lib.db.DbMongodb importDbMongodb

logging.basicConfig(level=logging.DEBUG,

format=‘%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s‘,

datefmt=‘%a, %d %b %Y %H:%M:%S‘,

filename=‘myapp.log‘,

filemode=‘w‘)

queue=Queue.Queue()

httpsqs= HttpsqsClient(‘192.168.0.218‘,‘1218‘,‘httpsqs.com‘)

db= DbMongodb(‘192.168.0.119‘,‘testdb‘)classThreadGetHttpSqs(threading.Thread):def __init__(self):

threading.Thread.__init__(self)

self.httpsqs=httpsqs

self.queue=queuedefrun(self):whileTrue:

data= self.httpsqs.get(‘logtest‘)if data is notNone:

self.queue.put(data)

logging.info(‘get:id %s , tablename %s‘ %(self.getName(),data))else:

time.sleep(3)classThreadInsertDB(threading.Thread):def __init__(self):

threading.Thread.__init__(self)

self.queue=queue

self.db=dbdefrun(self):whileTrue:

chunk=self.queue.get()

s=json.loads(chunk)

tablename= s[‘table‘]

data= s[‘data‘]

self.db.save(tablename,data)

logging.info(‘insert:id %s , tablename %s‘ %(self.getName(),tablename))

self.queue.task_done()classMyDaemon(Daemon):def_run(self):whileTrue:for i in range(2):

t=ThreadGetHttpSqs()#t.setDaemon(True)

t.start()for i in range(2):

b=ThreadInsertDB()#t.setDaemon(True)

b.start()

#线程已经为永真循环,进程不能再循环

time.wait()if __name__ == "__main__":

daemon= MyDaemon(‘/tmp/daemon-example.pid‘)if len(sys.argv) == 2:if ‘start‘ == sys.argv[1]:

daemon.start()elif ‘stop‘ == sys.argv[1]:

daemon.stop()elif ‘restart‘ == sys.argv[1]:

daemon.restart()else:print "Unknown command"sys.exit(2)

sys.exit(0)else:print "usage: %s start|stop|restart" %sys.argv[0]

sys.exit(2)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值