欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python多路復用selector模塊的基本使用

 更新時間:2021年11月10日 08:25:25   作者:返回主頁__i視覺  
Python提供了selector模塊來實現IO多路復用,這篇文章給大家介紹了Python多路復用selector模塊的基本使用,感興趣的朋友一起看看吧

1. IO多路復用

O多路復用技術是使用一個可以同時監(jiān)視多個IO阻塞的中間人去監(jiān)視這些不同的IO對象,這些被監(jiān)視的任何一個或多個IO對象有消息返回,都將會觸發(fā)這個中間人將這些有消息IO對象返回,以供獲取他們的消息。

使用IO多路復用的優(yōu)點在于,進程在單線程的情況下同樣可以同時處理多個IO阻塞。與傳統的多線程/多進程模型比,I/O多路復用系統開銷小,系統不需要創(chuàng)建新的進程或者線程,也不需要維護這些進程和線程的運行,降底了系統的維護工作量,節(jié)省了系統資源,

Python提供了selector模塊來實現IO多路復用。同時,不同的操作系統上,這中間人的可選則的類型是不同的,目前常見的有,epoll, kqueue, devpoll, poll,select等;kqueue(BSD,mac支持),devpoll(solaris支持)和epoll的實現基本相同,epoll在Linux2.5+內核中實現,Windows系統只實現了select。

1.1. epoll,poll, select的比較

select和poll使用輪詢的方式去檢測監(jiān)視的所有IO是否有數據返回,需要不斷的遍歷每一個IO對象,這是一種費時的操作,效率較低。poll優(yōu)于select的一點是select限制了最大監(jiān)視IO數為1024,這對于需要大量網絡IO連接的服務器來顯然是不夠的;而poll對于這個個數沒有限制。但是這同樣面臨問題,在使用輪詢的方式監(jiān)視這些IO時,IO數越大,意味著每一次輪詢消耗的時間越多。效率也就越低,這是輪詢無法解決的問題。

epoll就是為了解決這樣的問題誕生的,首先他沒有最大的監(jiān)視的IO數的限制,并且沒有使用輪詢的方式去檢測這些IO,而是采用了事件通知機制和回調來獲取這些有消息返回的IO對象,只有“活躍”的IO才會主動的去調用callback函數。這個IO將會直接被處理而不需要輪詢。

2. selector模塊的基本使用

import selectors
import socket

# 創(chuàng)建一個socketIO對象,監(jiān)聽后將可以接受請求消息了
sock = socket.socket()
sock.bind(("127.0.0.1", 80))
sock.listen()

slt = selectors.DefaultSelector()  # 使用系統默認selector,Windows為select,linux為epoll
# 將這個socketIO對象加入到,select中監(jiān)視
slt.register(fileobj=sock, events=selectors.EVENT_READ, data=None)

# 循環(huán)處理消息
while True:
    # select方法:輪詢這個selector,當有至少一個IO對象有消息返回時候,將會返回這個有消息的IO對象
    ready_events = slt.select(timeout=None)
    print(ready_events)     # 準備好的IO對象們
    break

ready_events 為一個列表(代表注冊到這個select中的所有的有數據可接收IO對象),列表中的每一個元組為:

SelectorKey對象:

  • fileobj:注冊的socket對象
  • fd:文件描述符
  • data:注冊時我們傳入的參數,可以是任意值,綁定到一個屬性上,方便之后使用。

mask值

  • EVENT_READ : 表示可讀的; 它的值其實是1;
  • EVENT_WRITE: 表示可寫的; 它的值其實是2;
  • 或者二者的組合

例如:

[(SelectorKey(fileobj=<socket.socket fd=456, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 80)>, fd=456, events=1, data=None),
    1)]

處理這個請求,只需要使用該socket對應方法即可,該socket用于接收請求的連接,使用accept方法就可以處理這個請求。

當接受請求之后,又將會產生新的客戶端,我們將其放入selector中一并監(jiān)視,當有消息來時,如果是連接請求,handle_request()函數處理,如果是客戶端的消息,handle_client_msg()函數處理。

對于select中有兩類socket,所以我們需要判斷被激活后返回的socket是哪一種,再調用不同的函數做不同的請求。如果這個select中的socket種類有很多,將無法如此判斷。解決辦法就是將處理函數綁定到對應的selectkey對象中,可以使用data參數。

def handle_request(sock:socket.socket, mask):    # 處理新連接
    conn, addr = sock.accept()
    conn.setblocking(False)  # 設定非阻塞
    slt.register(conn, selector.EVENT_READ, data=handle_client_msg)

def handle_client_msg(sock:socket.socket, mask)  # 處理消息
    data = sock.recv()
    print(data.decode())

sock = socket.socket()
sock.bind(("127.0.0.1", 80))
sock.listen()

slt = selectors.DefaultSelector()
slt.register(fileobj=sock, events=selectors.EVENT_READ, data=handle_request)

while True:
    ready_events = slt.select(timeout=None)
    for event, mask in ready_events:
        event.data(event.fileobj, mask)
        # 不同的socket有不同data函數,使用自己綁定的data函數調用,再將自己的socket作為參數。就可以處理不同類型的socket。

上面使用data很好的解決了上面問題,但是需要注意,綁定到data屬性上函數(或者說可調用對象)最終會使用event.data(event.fileobj)的方式調用,這些函數接受的參數應該相同。

到此這篇關于Python多路復用selector模塊的文章就介紹到這了,更多相關Python selector模塊內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 一個計算身份證號碼校驗位的Python小程序

    一個計算身份證號碼校驗位的Python小程序

    閑著無事,便想寫個實用點的Python小程序,如何計算機身份證號碼的校驗位,這樣的文章在網上一抓一大把,這里僅簡單介紹下吧
    2014-08-08
  • 使用Python遍歷文件夾實現查找指定文件夾

    使用Python遍歷文件夾實現查找指定文件夾

    這篇文章主要為大家介紹了如何使用Python遍歷文件夾從而實現查找指定文件夾下所有相同名稱的文件、所有相同后綴名的文件,感興趣的可以了解一下
    2022-07-07
  • 使用Python裝飾器在Django框架下去除冗余代碼的教程

    使用Python裝飾器在Django框架下去除冗余代碼的教程

    這篇文章主要介紹了使用Python裝飾器在Django框架下去除冗余代碼的教程,主要是處理JSON代碼的一些冗余,需要的朋友可以參考下
    2015-04-04
  • Python實現將JSON格式文件導入redis

    Python實現將JSON格式文件導入redis

    這篇文章主要為大家詳細介紹了Python實現將JSON格式文件導入redis的多種方法,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-01-01
  • 對Django項目中的ORM映射與模糊查詢的使用詳解

    對Django項目中的ORM映射與模糊查詢的使用詳解

    今天小編就為大家分享一篇對Django項目中的ORM映射與模糊查詢的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • python SQLAlchemy的Mapping與Declarative詳解

    python SQLAlchemy的Mapping與Declarative詳解

    這篇文章主要介紹了python SQLAlchemy的Mapping與Declarative詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-07-07
  • Python使用Pandas生成日報的實現代碼

    Python使用Pandas生成日報的實現代碼

    Pandas是Python中一個強大的數據處理庫,它提供了許多功能強大的數據結構和數據分析工具,在本文中,我們將介紹Pandas的基本概念和如何使用它生成一個包含今天到未來20個工作日的日期列表的Excel文件,需要的朋友可以參考下
    2023-11-11
  • Python匹配中文的正則表達式

    Python匹配中文的正則表達式

    正則表達式是一個特殊的字符序列,它能幫助你方便的檢查一個字符串是否與某種模式匹配。接下來通過本文給大家介紹Python匹配中文的正則表達式,感興趣的朋友一起學習吧
    2016-05-05
  • 使用Python操作FTP實現上傳和下載的方法

    使用Python操作FTP實現上傳和下載的方法

    今天小編就為大家分享一篇關于使用Python操作FTP實現上傳和下載的方法,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • 使用PyCharm官方中文語言包漢化PyCharm

    使用PyCharm官方中文語言包漢化PyCharm

    這篇文章主要介紹了使用PyCharm官方中文語言包漢化PyCharm,需要的朋友可以參考下
    2020-11-11

最新評論