python中aioysql方法的作用是什么-創(chuàng)新互聯(lián)

本篇文章為大家展示了python中aioysql方法的作用是什么,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了鄠邑免費(fèi)建站歡迎大家使用!

python異步IO初探

探索異步IO執(zhí)之前,先說說IO的種類

1.阻塞IO最簡(jiǎn)單,即讀寫數(shù)據(jù)時(shí),需要等待操作完成,才能繼續(xù)執(zhí)行。進(jìn)階的做法就是用多線程來處理需要IO的部分,缺點(diǎn)是開銷會(huì)有些大。

2.非阻塞IO,即讀寫數(shù)據(jù)時(shí),如果暫時(shí)不可讀寫,則立刻返回,而不等待。因?yàn)椴恢朗裁磿r(shí)候是可讀寫的,所以輪詢時(shí)可能會(huì)浪費(fèi)CPU時(shí)間。

3.IO復(fù)用,即在讀寫數(shù)據(jù)前,先檢查哪些描述符是可讀寫的,再去讀寫。select 和 poll 就是這樣做的,它們會(huì)遍歷所有被監(jiān)視的描述符,查看是否滿足,這個(gè)檢查的過程是阻塞的。而 epoll、kqueue 和/dev/poll 則做了些改進(jìn),事先注冊(cè)需要檢查哪些描述符的哪些事件,當(dāng)狀態(tài)發(fā)生變化時(shí),內(nèi)核會(huì)調(diào)用對(duì)應(yīng)的回調(diào)函數(shù),將這些描述符保存下來;下次獲取可用的描述符時(shí),直接返回這些發(fā)生變化的描述符即可。

4.信號(hào)驅(qū)動(dòng),即描述符就緒時(shí),內(nèi)核發(fā)送SIGIO信號(hào),再由信號(hào)處理程序處理這些信號(hào)即可。不過信號(hào)處理的時(shí)機(jī)是從內(nèi)核態(tài)返回用戶態(tài)時(shí),感覺也得把這些事件收集起來才好處理,有點(diǎn)想模擬IO復(fù)用了。

5.最后時(shí)異步IO,即讀寫數(shù)據(jù)時(shí),只注冊(cè)事件,內(nèi)核完成讀寫后(讀取的數(shù)據(jù)會(huì)復(fù)制到用戶態(tài)),再調(diào)用事件處理函數(shù)。這整個(gè)過程都不會(huì)阻塞調(diào)用線程。

Python 3.4 開始,標(biāo)準(zhǔn)庫里又新增了 asyncio 這個(gè)模塊。

從原理上來說,它和 Tornado 其實(shí)差不多,都是注冊(cè) IO 事件,然后在 IO loop 中等待事件發(fā)生,然后調(diào)用相應(yīng)的處理函數(shù)。

aiomysql說明

1. poll

此庫提供一個(gè)簡(jiǎn)單的連接對(duì)象用法:

import asyncio
import aiomysql
loop = asyncio.get_event_loop()
@asyncio.coroutine
def go()
 pool = yield from aiomysql.create_pool(host='127.0.0.1', port=3306,
           user='root', password='',
           db='mysql', loop=loop)
 with (yield from pool) as conn:
  cur = yield from conn.cursor()
  yield from cur.execute("SELECT 10")
  # print(cur.description)
  (r,) = yield from cur.fetchone()
  assert r == 10
 pool.close()
 yield from pool.wait_closed()
loop.run_until_complete(go())

解釋:

create_pool(minsize=1, maxsize=10, loop=None, **kwargs)

一個(gè)協(xié)程,創(chuàng)建連接池,連接database

參數(shù):

minsize(int)最小的池子 , 反之maxsize(int)
loop一個(gè)可選的事件循環(huán)實(shí)例,若未循環(huán),使用 asyncio.get_event_loop()
echo(bool)默認(rèn)log執(zhí)行SQL查詢
kwargs
Class pool:最重要的是獲得連接:

with (yield from pool) as conn:
 cur = yield from conn.cursor()

2.  aiomysql — API Reference

connection

該庫用來連接MySQL,使用簡(jiǎn)單的aiomysql.connect(),可以連接一個(gè)數(shù)據(jù)庫或者關(guān)聯(lián)池子以連接更多

import asyncio # 舉例說明
import aiomysql
loop = asyncio.get_event_loop()
@asyncio.coroutine
def test_example():
 conn = yield from aiomysql.connect(host='127.0.0.1', port=3306,
          user='root', password='', db='mysql',
          loop=loop)
 cur = yield from conn.cursor()
 yield from cur.execute("SELECT Host,User FROM user")
 print(cur.description)
 r = yield from cur.fetchall()
 print(r)
 yield from cur.close()
 conn.close()
loop.run_until_complete(test_example())

3. Cursors 游標(biāo)

import asyncio
import aiomysql
loop = asyncio.get_event_loop()
@asyncio.coroutine
def test_example():
 conn = yield from aiomysql.connect(host='127.0.0.1', port=3306,
          user='root', password='',
          db='mysql', loop=loop)
 # create default cursor
 cursor = yield from conn.cursor()
 # execute sql query # 執(zhí)行sql查詢
 yield from cursor.execute("SELECT Host, User FROM user")
 # fetch all results
 r = yield from cursor.fetchall()
 # detach cursor from connection
 yield from cursor.close()
 # close connection
 conn.close()
loop.run_until_complete(test_example())

python的五大特點(diǎn)是什么

python的五大特點(diǎn):1.簡(jiǎn)單易學(xué),開發(fā)程序時(shí),專注的是解決問題,而不是搞明白語言本身。2.面向?qū)ο?,與其他主要的語言如C++和Java相比, Python以一種非常強(qiáng)大又簡(jiǎn)單的方式實(shí)現(xiàn)面向?qū)ο缶幊獭?.可移植性,Python程序無需修改就可以在各種平臺(tái)上運(yùn)行。4.解釋性,Python語言寫的程序不需要編譯成二進(jìn)制代碼,可以直接從源代碼運(yùn)行程序。5.開源,Python是 FLOSS(自由/開放源碼軟件)之一。

上述內(nèi)容就是python中aioysql方法的作用是什么,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

當(dāng)前標(biāo)題:python中aioysql方法的作用是什么-創(chuàng)新互聯(lián)
分享網(wǎng)址:http://www.muchs.cn/article32/depisc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、網(wǎng)站排名、營銷型網(wǎng)站建設(shè)、網(wǎng)站制作外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司