色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Python多線程實現支付模擬請求過程解析

瀏覽:103日期:2022-07-29 13:28:20

思路:

隊列使用說明:

 multiprocessing.Queue()#用于進程間通信,單主進程與子進程無法通信(使用進程池時盡量不要使用這個)  multiprocessing.Manager().Queue()#用于主子進程通信,通過進程池(pool)創建的進程可以數據共享  queue.Queue()#用于線程間通信,同一進程內的數據可以共享

1.從數據庫里獲取待支付的訂單

2.將獲取出來的數據添加至隊列(queue.Queue()),并在函數中返回消息隊列的長度

3.根據隊列長度創建對應的線程數量

4.把創建的線程放在list

5.依次啟動

6.最后等待主線程執行完結束,統計函數運行時長

代碼如下

import asyncioimport sysfrom queue import Queuesys.path.append('../')from tool.__init__ import *from tool.decorator_token import *import timefrom threading import Thread,Lockclass 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_idt'+'order_sntn' #文件首行數據 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_snwith open(DoWeChatNotify_file,’a’,encoding=’utf-8’) as file2:#文件寫入 str_DoWeChatNotifyInfo=str(fwh_order_id)+’t’+str(fwh_order_sn)+’tn’ 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:4timestamp:157129653969sign: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 編程
相關文章:
主站蜘蛛池模板: 精品视频免费在线观看 | 一级做a爰片性色毛片中国 一级做a爰性色毛片 | 特级毛片8级毛片免费观看 特级毛片免费观看视频 | 日韩特黄特色大片免费视频 | 成人免费网站视频 | 国产高清一区二区三区 | 12至16末成年毛片视频 | 免费嗨片 | 亚洲精品国产第一区第二区国 | 亚洲男人天堂久久 | 亚洲一级毛片 | 国产三香港三韩国三级不卡 | 欧美久久久久 | 99在线观看巨臀大臀视频 | 久久精品久久精品久久精品 | 免费观看一级成人毛片 | 一级aaaaa毛片免费视频 | 天天五月天丁香婷婷深爱综合 | 欧美久草| 福利三区| 欧美一级手机免费观看片 | 国产成人精品福利网站在线 | 国产三级日产三级日本三级 | 久久成人a毛片免费观看网站 | 男女视频在线观看 | 99精品久久精品一区二区 | 成人男女啪啪免费观看网站 | 黄色视屏免费 | 最新在线步兵区 | 欧美午夜视频一区二区 | 日韩乱淫 | 一区二区在线欧美日韩中文 | 日本久久精品视频 | 亚洲一级毛片欧美一级说乱 | 欧美在线一 | 欧美全免费aaaaaa特黄在线 | 欧美中文字幕一区 | 欧美日韩精品在线播放 | 波多野结衣一级片 | 亚洲国产剧情在线精品视 | 一区二区不卡在线 |