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

#!/usr/bin/python

import sys,time,json,logging

import Queue, threading, datetime

from lib.base.daemon import Daemon

from lib.queue.httpsqs.HttpsqsClient import HttpsqsClient

from lib.db.DbMongodb import DbMongodb

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')

class ThreadGetHttpSqs(threading.Thread):

def __init__(self):

threading.Thread.__init__(self)

self.httpsqs = httpsqs

self.queue = queue

def run(self):

while True:

data = self.httpsqs.get('logtest')

if data is not None:

self.queue.put(data)

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

else:

time.sleep(3)

class ThreadInsertDB(threading.Thread):

def __init__(self):

threading.Thread.__init__(self)

self.queue = queue

self.db = db

def run(self):

while True:

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()

class MyDaemon(Daemon):

def _run(self):

while True:

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)

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值