激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - 實例分析python3實現并發訪問水平切分表

實例分析python3實現并發訪問水平切分表

2021-04-05 00:21腳本之家 Python

在本文中小編給大家整理了關于python3實現并發訪問水平切分表的相關知識點以及實例代碼,有興趣的朋友們參考下。

場景說明

假設有一個mysql表被水平切分,分散到多個host中,每個host擁有n個切分表。

如果需要并發去訪問這些表,快速得到查詢結果, 應該怎么做呢?

這里提供一種方案,利用python3的asyncio異步io庫及aiomysql異步庫去實現這個需求。

代碼演示

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import logging
import random
import asynciofrom aiomysql
import create_pool
# 假設mysql表分散在8個host, 每個host有16張子表
TBLES = "192.168.1.01": "table_000-015",
# 000-015表示該ip下的表明從table_000一直連續到table_015
  "192.168.1.02": "table_016-031",
   "192.168.1.03": "table_032-047"
    "192.168.1.04": "table_048-063",
     "192.168.1.05": "table_064-079"
     "192.168.1.06": "table_080-095",
      "192.168.1.07": "table_096-0111",
       "192.168.1.08": "table_112-0127",
}
USER = "xxx"PASSWD = "xxxx"# wrapper函數,用于捕捉異常def query_wrapper(func):
  async def wrapper(*args, **kwargs):
    try:
      await func(*args, **kwargs)    except Exception as e:
      print(e)  return wrapper
      # 實際的sql訪問處理函數,通過aiomysql實現異步非阻塞請求@
      query_wrapperasync def query_do_something(ip, db, table):
  async with create_pool(host=ip, db=db, user=USER, password=PASSWD) as pool:
    async with pool.get() as conn:
      async with conn.cursor() as cur:
        sql = ("select xxx from {} where xxxx")
        await cur.execute(sql.format(table))
        res = await cur.fetchall()   
 # then do something...# 生成sql訪問隊列, 隊列的每個元素包含要對某個表進行訪問的函數及參數def gen_tasks():
  tasks = []  for ip, tbls in TBLES.items():
    cols = re.split('_|-', tbls)
    tblpre = "_".join(cols[:-2])
    min_num = int(cols[-2])
    max_num = int(cols[-1])  
      for num in range(min_num, max_num+1):
      tasks.append(
        (query_do_something, ip, 'your_dbname', '{}_{}'.format(tblpre, num))
      )
 
  random.shuffle(tasks) 
   return tasks# 按批量運行sql訪問請求隊列def run_tasks(tasks, batch_len):
  try
    for idx in range(0, len(tasks), batch_len):
      batch_tasks = tasks[idx:idx+batch_len]
      logging.info("current batch, start_idx:%s len:%s" % (idx, len(batch_tasks)))
            for i in range(0, len(batch_tasks)):
        l = batch_tasks[i]
        batch_tasks[i] = asyncio.ensure_future(
          l[0](*l[1:])
        )
      loop.run_until_complete(asyncio.gather(*batch_tasks))
       except Exception as e:
    logging.warn(e)# main方法, 通過asyncio實現函數異步調用def main():
  loop = asyncio.get_event_loop()
 
  tasks = gen_tasks()
  batch_len = len(TBLES.keys()) * 5  # all up to you
  run_tasks(tasks, batch_len)
 
  loop.close()

以上就是本次相關內容的全部實例代碼,大家可以本地測試以下,感謝你對服務器之家的支持。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费h片网站 | 毛片av网址 | 色妞视频男女视频 | 男女羞羞视频在线免费观看 | 国产一区二区三区视频在线观看 | 中文字幕在线日韩 | 国产精品一区二区手机在线观看 | 91精品最新国内在线播放 | 性看小视频 | 国产日本欧美在线观看 | 免费国产成人高清在线看软件 | 亚洲精品永久视频 | 久久不射电影网 | 国产成人免费精品 | 香蕉国产 | 国产精品久久久久久久成人午夜 | 色婷婷久久久 | 日韩视频在线一区二区三区 | 韩国十九禁高潮床戏在线观看 | 国产成人强伦免费视频网站 | 国产精品久久国产精麻豆96堂 | 国产精品二区高清在线 | 欧美一级高潮片免费的 | 欧美一级爱操视频 | chinese-xvideos | 久久久日韩av免费观看下载 | 久草最新在线 | 一级免费特黄视频 | 亚洲免费片 | 国产精品亚洲欧美 | 特片网久久 | 666sao| 欧美日韩国产成人在线观看 | 孕妇体内谢精满日本电影 | 宅男噜噜噜66国产免费观看 | 美女视频黄视大全视频免费网址 | 午夜视频在线观看免费视频 | 亚洲男人一区 | 精品一区二区三区免费视频 | 深夜福利视频绿巨人视频在线观看 | 亚洲免费在线视频 |