python eventlet綠化和patch原理
說明
eventlet是一個必備工具,經(jīng)常用,綠化原理有點忘記了,重新復(fù)習(xí)一遍.
三個主要問題
1. 綠化的原理是什么?2. 綠化怎么管理?3. 綠化怎么引入?
綠化原理
利用select/epolls/kqueue等操作系統(tǒng)提供的非阻塞操作,將阻塞改為非阻塞.
引用管理
eventlet在import之后,將模塊中的屬性綠化.用一小段代碼來查看看
import sysimport eventlet# eventlet.monkey_patch() httplib2 = eventlet.import_patched(’httplib2’)print(httplib2)print(httplib2.socket) print('================')for k,v in sys.modules.items(): if 'socket' in k: print(k, v) # 打印內(nèi)容<module ’httplib2’ from ’D:workspacevenvxxxlibsite-packageshttplib2__init__.py’><module ’eventlet.green.socket’ from ’D:workspacevenvxxxlibsite-packageseventletgreensocket.py’>================_socket <module ’_socket’ from ’c:pythonpython36DLLs_socket.pyd’>socket <module ’socket’ from ’c:pythonpython36libsocket.py’>__original_module_socket <module ’socket’ from ’c:pythonpython36libsocket.py’> # 說明了什么?綠化只是替換httplib2模塊中的引用屬性socket。并未改變sys.modules中的屬性
引入綠化方法一:直接import
from eventlet.green import socket
引入綠化方法二:eventlet.import_patch
1.好處: 能綠化模塊內(nèi)部的系統(tǒng)模塊2.只能綠化os, select, socket, thread, time, psycopy, MySQLdb, bultines, subprocess3.如果是import threading,不會自動綠化, 需要from eventlet.green import threading
import eventlethttplib2 = eventlet.import_patched(’httplib2’)print(httplib2)print(httplib2.socket) # 打印<module ’httplib2’ from ’D:workspacevenvautumn-secslibsite-packageshttplib2__init__.py’><module ’eventlet.green.socket’ from ’D:workspacevenvautumn-secslibsite-packageseventletgreensocket.py’>
引入綠化方法三:eventlet.monkey_patch
1.與import_patch不同,會直接修改sys.modules2.但是也只能綠化os,select等等幾個模塊,其它模塊需要用直接引用綠化
以上就是python eventlet綠化和patch原理的詳細(xì)內(nèi)容,更多關(guān)于python eventlet的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. IntelliJ IDEA設(shè)置默認(rèn)瀏覽器的方法2. idea設(shè)置提示不區(qū)分大小寫的方法3. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))4. IntelliJ IDEA創(chuàng)建web項目的方法5. VMware中如何安裝Ubuntu6. ASP.NET MVC通過勾選checkbox更改select的內(nèi)容7. .NET SkiaSharp 生成二維碼驗證碼及指定區(qū)域截取方法實現(xiàn)8. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )9. docker容器調(diào)用yum報錯的解決辦法10. django創(chuàng)建css文件夾的具體方法
