掃二維碼與項(xiàng)目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
Python socket服務(wù)需要我們進(jìn)行不斷的學(xué)習(xí),因?yàn)閺V泛的應(yīng)用需要不斷的學(xué)習(xí)。下面就是一些詳細(xì)的介紹。希望對大家有所幫助。首先,要明白不是所有的socket服務(wù)都需要高性能。

武寧網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站開發(fā)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)于2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
如果要求高性能,使用IOCP或EPoll模式用C/C++來完成,直接用API寫,用ACE的proactor封裝來完成是比較恰當(dāng)?shù)男袨?。但?dāng)性能不是主要問題時,用Python socket服務(wù),并享受高的開發(fā)效率將是一件快樂的事。下面,是用Python socket服務(wù)完成的一個每thread/connect的一個echo服務(wù)。
經(jīng)常的,在寫一段Python socket服務(wù)代碼時,我會先打開《Python Cookbook》(O'Reilly)一書,看看有沒有所需要的(這也是保證效率的一種方式),下面的代碼就是摘自此書。
- import SocketServer
- class MyHandler(SocketServer.BaseRequestHandler):
- def handle(self):
- while 1:
- dataReceived = self.request.recv(1024)
- if not dataReceived: break
- self.request.send(dataReceived)
- myServer = SocketServer.ThreadingTCPServer(('',8881), MyHandler)
- myServer.serve_forever( )
只用數(shù)行代碼就完成工作,是不是非常輕松愉快。注意,這還不是一個實(shí)用程序,只是一個簡單的示例。但這個示例指示了方向,下面我會把完成一個真正的服務(wù)端的一些小技巧一一列出。不過,在這之前,用幾行代碼完成一個測試用的客戶端是一個不錯的主意:
- import socket
- remote_host = '127.0.0.1'
- remote_port = 9919
- send_buf = open('binary.txt', 'rb').read()
- #send_bufsend_buf = send_buf.replace('\x0D\x0A', '')
- ock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
- sock.connect((remote_host, remote_port))
- sock.send(send_buf)
- response_data = sock.recv(1024)
- print response_data
- sock.close( )
看著上面寫的這些代碼,是不是感覺開發(fā)效率不一般的高 ^_^,下面進(jìn)入正題
現(xiàn)在,我們來解決遇到***個問題,MyHander是繼承自SocketServer.BaseRequestHandler,但文檔對這個模塊介紹不怎么詳細(xì)。不詳細(xì)的原因?我想是因?yàn)檫@個類實(shí)在很簡單。打開Lib目錄下的SocketServer.py文件,我們直接看代碼:
- class BaseRequestHandler:
- def __init__(self, request, client_address, server):
- self.request = request
- self.client_address = client_address
- self.server = server
- try:
- self.setup()
- self.handle()
- self.finish()
- finally:
- sys.exc_traceback = None # Help garbage collection
- def setup(self):
- pass
- def handle(self):
- pass
- def finish(self):
- pass
以上就是對Python socket服務(wù)的詳細(xì)介紹。一眼可知,類實(shí)現(xiàn)的是一個簡單的template模式,定義了setup, handle, finish讓繼承者重載,模式方法__init__則定義了三個方法的調(diào)用順序同時保證三個方法的運(yùn)行。 很顯然,如果我們要在退出時關(guān)閉連接,重定義finish是一個很自然的行為。
【編輯推薦】

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流