python秒杀商品 多线程_Python多线程/队列生成器和消费者竞争问题

我有以下python代码,每个线程正在执行以下角色 .

制片人 - 生成json文本

Processor-解析json并生成json对象列表

消费者 - 获取列表并持久保存到数据存储

生产环境 者发送json和消费者获取json列表,问题是消息计数从 生产环境 者到消费者不匹配 . 一些消息正在消失之间 . 我看到生成器和解析器之间的消息计数是同步的 .

已解决:我必须在将它们发布到队列/列表后创建新对象 . 在我之前的代码中,我只是通过清除它们来重新使用列表和dict对象(可能是我在思考:)) . 这导致对象数据在队列中被清除,因为下游线程尚未消耗它...

以下是工作代码

import threading

import sys, time

import logging

import random

import Queue, json

from datetime import datetime

logging.basicConfig(level=logging.DEBUG,

format='(%(threadName)-9s) %(message)s', )

MAX_SIZE = -1

producerq = Queue.Queue(maxsize=MAX_SIZE)

consumerq = Queue.Queue(maxsize=MAX_SIZE)

class ProduceJson(threading.Thread):

def __init__(self, group=None, target=None, name=None,

args=(), kwargs=None, verbose=None, producerq=producerq):

super(ProduceJson, self).__init__()

self.target = target

self.name = name

self.producerq = producerq

logging.debug(self.name +" Started")

return

def run(self):

cnt = 1

try:

while True:

#time.sleep(2)

if not self.producerq.full():

timestamp = datetime.utcnow().strftime("%Y-%m-%dT%H:%M:%S6Z")

item = json.dumps({

'seq': cnt,

'timestamp': timestamp

})

logging.debug(self.name + " Posting " + str(item))

self.producerq.put(item)

cnt = cnt + 1

#logging.info(self.name + ' current count : ' + str(cnt))

except Exception as e:

logging.error("ERROR " + self.name + e.message)

return

class ParseJson(threading.Thread):

def __init__(self, group=None, target=None, name=None,

args=(), kwargs=None, verbose=None, producerq=producerq, consumerq=consumerq):

super(ParseJson, self).__init__()

self.target = target

self.name = name

self.producerq = producerq

self.consumerq = consumerq

logging.debug(self.name +" Started")

return

def run(self):

cnt = 0

itemlist = []

try:

while True:

#time.sleep(2)

if not self.producerq.empty():

item = json.loads(self.producerq.get())

#logging.debug(self.name+" Received "+ str(item))

pi = dict()

pi['pseq'] = item['seq']

pi['ptime'] = item['timestamp']

itemlist.append(pi)

#

if len(itemlist) == 5: # Load lits of 10 elements to queue

self.consumerq.put(itemlist)

logging.debug(self.name + " Posting " + str(itemlist) )

itemlist = []

cnt = cnt + 1

#logging.debug(self.name + ' current count : ' + str(cnt))

except Exception as e:

logging.error("ERROR " + self.name + e.message)

return

class ConsumeJsonList(threading.Thread):

def __init__(self, group=None, target=None, name=None,

args=(), kwargs=None, verbose=None, consumerq=consumerq):

super(ConsumeJsonList, self).__init__()

self.target = target

self.name = name

self.consumerq = consumerq

logging.debug(self.name +" Started")

return

def run(self):

cnt = 0

cl = []

try:

while True:

#time.sleep(2)

if not self.consumerq.empty():

cl = self.consumerq.get()

cnt = cnt + len(cl)

logging.info(" Consumed items "+ str(cl) )

cl = []

#else:

# logging.debug(self.name + '****Is EMPTY**')

#

#logging.info(self.name + ' current count : ' + str(cnt))

except Exception as e:

logging.error("ERROR " + self.name + e.message)

return

if __name__ == '__main__':

producer1 = ProduceJson(name='PRODUCER1', producerq=producerq)

#producer2 = ProduceJson(name='PRODUCER1', producerq=producerq)

parser1 = ParseJson(name='parser1', producerq=producerq, consumerq=consumerq)

parser2 = ParseJson(name='parser2', producerq=producerq, consumerq=consumerq)

#parser3 = ParseJson(name='parser2', producerq=producerq, consumerq=consumerq)

consumer1 = ConsumeJsonList(name='CONSUMER1', consumerq=consumerq)

#consumer2 = ConsumeJsonList(name='consumer2', consumerq=consumerq)

#consumer3 = ConsumeJsonList(name='consumer3', consumerq=consumerq)

######

producer1.start()

parser1.start()

parser2.start()

consumer1.start()

#consumer2.start()

#consumer3.start()

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值