Python多线程实现支付模拟请求过程解析


Posted in Python onApril 21, 2020

思路:

队列使用说明:

  •  multiprocessing.Queue()#用于进程间通信,单主进程与子进程无法通信(使用进程池时尽量不要使用这个)

  •  multiprocessing.Manager().Queue()#用于主子进程通信,通过进程池(pool)创建的进程可以数据共享

  •  queue.Queue()#用于线程间通信,同一进程内的数据可以共享

1.从数据库里获取待支付的订单

2.将获取出来的数据添加至队列(queue.Queue()),并在函数中返回消息队列的长度

3.根据队列长度创建对应的线程数量

4.把创建的线程放在list

5.依次启动

6.最后等待主线程执行完结束,统计函数运行时长

代码如下

import asyncio
import sys
from queue import Queue
sys.path.append("../")
from tool.__init__ import *
from tool.decorator_token import *
import time
from threading import Thread,Lock

class doWeChatNotify(BaseTest):
  def __init__(self):
    super().__init__()
    self.limit_num=100 #查询记录条数
    self.WeChatNotify_sql='''select order_id,order_sn from fw_order where `status`=0 
            and course_id=1569 ORDER BY create_time desc limit %d ;'''%(self.limit_num)
    self.fwh_test_api=fwh_test_api
    self.data = self.my_op.sql_operation_fwh(self.WeChatNotify_sql)
    self.fwh_order_dict = {}
    self.que = Queue()


  @token_fwh#验证token有效性
  def get_fwh_token_list(self):
    token_list=self.fwh_token.loadTokenList()
    return token_list

  @token_crm#验证token有  def get_crm_token_list(self)    token_list=self.token.loadTokenList()
    return token_list

  def testDoWeChatNotify(self):
    DoWeChatNotify_file='../tokenFileAndtxtFiles'+'/'+"DoWeChatNotify_asynchronousPay.txt"
    with open(DoWeChatNotify_file,'a',encoding='utf=-8') as file:
      str_first="order_id\t"+"order_sn\t\n" #文件首行数据
      file.write(str_first)
    fwh_order_id_list, fwh_order_sn_list = [], []

    if self.data!=():
      for a in self.data:
        fwh_order_id=a['order_id']
        fwh_order_sn=a['order_sn']
        self.fwh_order_dict[fwh_order_id]=fwh_order_sn

        with open(DoWeChatNotify_file,'a',encoding='utf-8') as file2:#文件写入
          str_DoWeChatNotifyInfo=str(fwh_order_id)+'\t'+str(fwh_order_sn)+'\t\n'
          file2.flush() #清除缓冲区
          file2.write(str_DoWeChatNotifyInfo)
        self.que.put(self.fwh_order_dict)#将数据添加至队列
    #关闭数据库连接
    # self.my_op.close_db_fwh()
    # self.my_op.close_db()
    return self.que.qsize()#返回队列数量

  def asynchronousPay(self,order_id,order_sn):
    count=1
    count_num=50
    token_list=self.get_fwh_token_list()
    if (self.data!=()):
      headers_form_urlencoded['token']=token_list[0]
      url_wechat_success_huidiao=self.fwh_test_api+'/index/Order/doWeChatNotify'
      data_wechat_success_huidiao=self.data_to_str.requestDataToStr_firefoxAndChrome_fwh('''order_sn:{}
order_id:{}
meth_id:4
timestamp:157129653969
sign:0687b01b300b9e300d3996a9d2173f1380973e5a'''.format(order_sn,order_id))
      request_wechat_success_huidiao=requests.post(url=url_wechat_success_huidiao,headers=headers_form_urlencoded,data=data_wechat_success_huidiao)
      response_wechat_success_huidiao=request_wechat_success_huidiao.json()
      if '订单状态错误,非待支付订单' in response_wechat_success_huidiao['msg']:
        print(data_wechat_success_huidiao)
    else:
      print('待支付订单为空')

  def run_multithreading(self):#多线程
    threads = []#存放所有的线程
    nloops = list(range(self.testDoWeChatNotify()))#获取队列数量
    if len(nloops)>0:
      for i,k in zip(nloops,self.que.get().items()):#根据队列数量来创建线程
        t = Thread(target=self.asynchronousPay,args=(k[0],k[1]))
        threads.append(t)

      for s in nloops: # 开始多线程
        threads[s].start()

      for j in nloops: # 等待所有线程完成
        threads[j].join()
    else:
      print("队列数量为空")

if __name__=="__main__":
  start_time = time.time() # 计算程序开始时间
  wechfy=doWeChatNotify()
  wechfy.run_multithreading()#多线程
  print('程序耗时{:.2f}'.format(time.time() - start_time)) # 计算程序总耗时

总结:亲测运行时间还是会快很多,单线程支付100个订单四十几秒的样子,多线程运行不用join2.x秒,用join八秒的样子,还有很大的优化空间,因为运行时会创建100个线程

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python Django模板的使用方法(图文)
Nov 04 Python
pycharm 使用心得(八)如何调用另一文件中的函数
Jun 06 Python
详解Python中的__new__()方法的使用
Apr 09 Python
Python中subprocess模块用法实例详解
May 20 Python
python查看zip包中文件及大小的方法
Jul 09 Python
用python写的一个wordpress的采集程序
Feb 27 Python
python中requests小技巧
May 10 Python
Python实现基本数据结构中栈的操作示例
Dec 04 Python
使用Python读取安卓手机的屏幕分辨率方法
Mar 31 Python
Python用csv写入文件_消除空余行的方法
Jul 06 Python
不知道这5种下划线的含义,你就不算真的会Python!
Oct 09 Python
python3爬虫中多线程进行解锁操作实例
Nov 25 Python
安装多个版本的TensorFlow的方法步骤
Apr 21 #Python
解决Jupyter notebook中.py与.ipynb文件的import问题
Apr 21 #Python
TensorFLow 数学运算的示例代码
Apr 21 #Python
jupyter修改文件名方式(TensorFlow)
Apr 21 #Python
Python基于requests实现模拟上传文件
Apr 21 #Python
Ubuntu中配置TensorFlow使用环境的方法
Apr 21 #Python
基于jupyter代码无法在pycharm中运行的解决方法
Apr 21 #Python
You might like
SONY ICF-SW07收音机电路分析
2021/03/02 无线电
磨咖啡豆的密诀
2021/03/03 冲泡冲煮
php获取文件大小的方法
2014/02/26 PHP
phpMyAdmin自动登录和取消自动登录的配置方法
2014/05/12 PHP
PHP采用XML-RPC构造Web Service实例教程
2014/07/16 PHP
详解PHP中array_rand函数的使用方法
2016/09/11 PHP
js 加载并解析XML字符串的代码
2009/12/13 Javascript
JS的document.all函数使用示例
2013/12/30 Javascript
JavaScript高级教程5.6之基本包装类型(详细)
2015/11/23 Javascript
JavaScript获取当前cpu使用率的方法
2015/12/15 Javascript
基于jquery实现三级下拉菜单
2016/05/10 Javascript
AngularJS指令与指令之间的交互功能示例
2016/12/14 Javascript
一句jQuery代码实现返回顶部效果(简单实用)
2016/12/28 Javascript
详解Webpack-dev-server的proxy用法
2018/09/08 Javascript
在Vue项目中使用jsencrypt.js对数据进行加密传输的方法
2019/04/17 Javascript
帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)
2019/08/23 Javascript
利用原生JS实现欢乐水果机小游戏
2020/04/23 Javascript
[49:08]完美世界DOTA2联赛PWL S2 LBZS vs FTD.C 第一场 11.27
2020/12/01 DOTA
python连接MySQL、MongoDB、Redis、memcache等数据库的方法
2013/11/15 Python
在Python中使用swapCase()方法转换大小写的教程
2015/05/20 Python
开始着手第一个Django项目
2015/07/15 Python
django rest framework之请求与响应(详解)
2017/11/06 Python
将Dataframe数据转化为ndarry数据的方法
2018/06/28 Python
Python3使用腾讯云文字识别(腾讯OCR)提取图片中的文字内容实例详解
2020/02/18 Python
python中常见错误及解决方法
2020/06/21 Python
若干个Java基础面试题
2015/05/19 面试题
与C++相比,Java中的数组有什么不同
2014/03/25 面试题
《东方明珠》教学反思
2014/04/20 职场文书
个人考核材料
2014/05/15 职场文书
李白故里导游词
2015/02/12 职场文书
会计工作检讨书
2015/02/19 职场文书
2016领导干部廉洁自律心得体会
2016/01/13 职场文书
2019毕业论文致谢词
2019/06/24 职场文书
pytorch加载预训练模型与自己模型不匹配的解决方案
2021/05/13 Python
python ansible自动化运维工具执行流程
2021/06/24 Python
Python爬取用户观影数据并分析用户与电影之间的隐藏信息!
2021/06/29 Python