python标准库之socket_python标准库SocketServer学习
導語:大牛們常常說閱讀源碼是很低效的學習方法。但對我輩初學者而言,閱讀源碼卻是掌握編程思想、編碼規范的好途徑。簡而言之,讀源碼不是萬能的,不讀源碼是萬萬不能的。
SocketServer是標準庫中一個很具有代表性的庫。它基于socket提供一套快速建立socket服務器的框架,并可以通過Mix-in的技巧讓單線程服務器進化為多線程或多進程服務器。Socketserver.py里面的類很多,下面一個一個介紹并介紹它們之間關系。
BaseServer、TCPServer、UDPServer,前者是后兩者的父類。在父類中實現了TCP與UDP服務器可以共用的方法,并留下了需要在子類中實現的抽象類。因此在實際工作中,我們一般不應該繼承BaseServer類,除非你是為了自己去實現或重載某些方法。另外,還有UnixStreamServer和UnixDatagramServer分別繼承自TCPserver和UDPServer。這兩個帶Unix字樣的類是用來構建*nix下本地socket的服務器(本地socket訪問速度更快,但只能用在本機的進程間通信)
接下來是ForkingMixIn和ThreadingMixIn兩個混合類,它們都提供Server類中process_request方法的新實現,前者在處理每次用戶連接的時候都會開啟新的進程,而后者會開啟新的線程。想要讓Server類實現并發處理,只用利用多重繼承即可。或者直接使用已經混合好的
class ForkingUDPServer(ForkingMixIn, UDPServer): pass
class ForkingTCPServer(ForkingMixIn, TCPServer): pass
class ThreadingUDPServer(ThreadingMixIn, UDPServer): pass
class ThreadingTCPServer(ThreadingMixIn, TCPServer): pass
最后沒有介紹的是BaseRequestHandler、StreamRequestHandler、DatagramRequestHandler,同Server一樣,前者是后兩者的父類用來提供公用的方法
通常在使用SocketServer的時候我們只用自己實例化一個合適的Server類,并在實例化時傳遞其監聽的IP、端口,以及之前繼承自某個RequestHandler的類(需要自行實現hanle方法,作為server的請求處理器)
這里需要特別注意的:
1.IP和端口是作為一個元組傳遞的而不是兩個單獨的參數。
2.每個客戶連接都會在hanle方法運行完之后被關閉,你如果不想關閉就需要重寫Server中的def shutdown_request(self, request)方法
___________________我是華麗麗的分割線________________________
可以說這個標準庫用起來還很方便的,但功能上還是有一些不足。
1.它沒有提供各個hanle實例之間的通信機制,因此客戶端互發消息還是需要自己實現一個觀察者模型。
不過這個功能似乎也超過了SocketServer的工作職責了。我們可以自己實現,也可以使用python-message這個國產第三方庫來進行線程間基于消息的編程。
2.它提供了多線程多進程的解決方案,但沒有異步方案的server每次訪問都是阻塞的
關于這點我感覺很遺憾,不過這個庫也不是太復雜,大不了自己寫一個異步的socketserver吧,自己動手豐衣足食!
因為本來就是是對源碼的解讀,所以這篇文章沒有放什么代碼。讀者完全可以自己去標準庫里翻翻看,注釋寫的真的很贊。
本文原創發布php中文網,轉載請注明出處,感謝您的尊重!
總結
以上是生活随笔為你收集整理的python标准库之socket_python标准库SocketServer学习的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 代表:大学生没必要都在大城市卷 可以选择
- 下一篇: 白岩松评价中国女足:这四点强于男足!