基于python socketserver框架全面解析
socketserver框架是一個基本的socket服務(wù)器端框架, 使用了threading來處理多個客戶端的連接, 使用seletor模塊來處理高并發(fā)訪問, 是值得一看的python 標準庫的源碼之一
對于select網(wǎng)絡(luò)框架的理解可以看 << 基于python select.select模塊通信的實例講解 >>。socketserver框架采用了selector框架來供你選擇相適應(yīng)的網(wǎng)絡(luò)通信框架, 比如select, poll, epoll等。有了這些網(wǎng)絡(luò)框架我們就能處理高并發(fā)的網(wǎng)絡(luò)訪問了.
先看看示例代碼吧:
# coding: utf-8
import socketserver
class MyTCPHandler(socketserver.BaseRequestHandler):
"""
The request handler class for our server.
It is instantiated once per connection to the server, and must
override the handle() method to implement communication to the
client.
"""
def handle(self):
# self.request is the TCP socket connected to the client
self.data = self.request.recv(1024).strip()
print("{} wrote:".format(self.client_address[0]))
print(self.data)
# just send back the same data, but upper-cased
self.request.sendall(self.data.upper())
if __name__ == "__main__":
HOST, PORT = "localhost", 9999
# Create the server, binding to localhost on port 9999
# 如果子類沒有某個方法或是屬性, 就回去父類中調(diào)用
with socketserver.ThreadingTCPServer((HOST, PORT), MyTCPHandler) as server:
# Activate the server; this will keep running until you
# interrupt the program with Ctrl-C
server.serve_forever()
客戶端:
# coding: utf-8
import socket
sk = socket.socket()
sk.connect(("127.0.0.1", 9999)) # 主動初始化與服務(wù)器端的連接
while True:
send_data = input("輸入發(fā)送內(nèi)容:")
sk.sendall(bytes(send_data, encoding="utf8"))
if send_data == "byebye":
break
accept_data = str(sk.recv(1024), encoding="utf8")
print("".join(("接收內(nèi)容:", accept_data)))
sk.close()
我們創(chuàng)建一個繼承自BaseRequestHandler類的TCP請求處理類, 說白了這個類就是我們自己封裝的基于socket的recv()函數(shù)與send()函數(shù)的類, 而所謂的TCP請求處理類其實就是對socket服務(wù)器端的bind, listen, accept等處理的封裝類, 而且這個封裝的并不是簡單的socket, 而是基于select或是epoll等網(wǎng)絡(luò)框架的類, 我們調(diào)用這個類就能輕易地處理高并發(fā)的網(wǎng)絡(luò)訪問. 其實認真閱讀源碼, 你會發(fā)現(xiàn)整體的程序設(shè)計是基于事件驅(qū)動的, 事件驅(qū)動機制的三個要素: 消息(事件)隊列, 消息(事件)觸發(fā), 事件循環(huán)。只不過socketserver框架的事件驅(qū)動機制就做到了socket的accept()方法那, 接下來的消息接受(recv)與發(fā)送(send)就沒有在做封裝成相應(yīng)的事件來進行處理了。
在這里說一個要注意的地方, 我使用了ThreadingTCPServer()類響應(yīng)多個客戶端的連接, 但是當(dāng)我閱讀這個類的源碼的時候, 表示很疑惑??!
class ThreadingTCPServer(ThreadingMixIn, TCPServer): pass
這讓我很疑惑啊,再看看調(diào)用:
with socketserver.ThreadingTCPServer((HOST, PORT), MyTCPHandler) as server: # Activate the server; this will keep running until you # interrupt the program with Ctrl-C server.serve_forever()
這更疑惑, ThreadingTCPServer哪來的構(gòu)造函數(shù), 后來研究了一下, 原來當(dāng)子類的某個函數(shù)或是屬性發(fā)生調(diào)用時, 如果不是重載了父類的方法或是屬性, 而且子類中沒有這個方法或是屬性, 就會去調(diào)用父類相對應(yīng)的方法或是屬性, 于是上面的就是調(diào)用了TCPServer的初始化函數(shù)__init__以及serve_forever(), 隨后調(diào)用的是子類的Request_handler函數(shù)
程序結(jié)果:


以上這篇基于python socketserver框架全面解析就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- Python使用socketServer包搭建簡易服務(wù)器過程詳解
- python網(wǎng)絡(luò)編程:socketserver的基本使用方法實例分析
- Python探索之SocketServer詳解
- 利用Python中SocketServer 實現(xiàn)客戶端與服務(wù)器間非阻塞通信
- Python使用SocketServer模塊編寫基本服務(wù)器程序的教程
- 實例講解Python中SocketServer模塊處理網(wǎng)絡(luò)請求的用法
- python網(wǎng)絡(luò)編程之TCP通信實例和socketserver框架使用例子
- Python網(wǎng)絡(luò)編程之socket與socketserver
相關(guān)文章
使用Python實現(xiàn)炫酷的數(shù)據(jù)動態(tài)圖大全
數(shù)據(jù)可視化是通過圖形、圖表、地圖等可視元素將數(shù)據(jù)呈現(xiàn)出來,以便更容易理解、分析和解釋,它是將抽象的數(shù)據(jù)轉(zhuǎn)化為直觀形象的過程,本文給大家介紹了使用Python實現(xiàn)炫酷的數(shù)據(jù)動態(tài)圖大全,需要的朋友可以參考下2024-06-06
Python中八種數(shù)據(jù)導(dǎo)入方法總結(jié)
數(shù)據(jù)分析過程中,需要對獲取到的數(shù)據(jù)進行分析,往往第一步就是導(dǎo)入數(shù)據(jù)。導(dǎo)入數(shù)據(jù)有很多方式,不同的數(shù)據(jù)文件需要用到不同的導(dǎo)入方式,相同的文件也會有幾種不同的導(dǎo)入方式。下面總結(jié)幾種常用的文件導(dǎo)入方法2022-11-11
解決多個@Scheduled定時任務(wù)執(zhí)行時個別不執(zhí)行問題
這篇文章主要介紹了解決多個@Scheduled定時任務(wù)執(zhí)行時個別不執(zhí)行問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
利用Python通過商品條形碼查詢商品信息的實現(xiàn)示例
這篇文章主要介紹了利用Python通過商品條形碼查詢商品信息,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
Python?jieba庫文本處理詞性標注和關(guān)鍵詞提取進行文本情感分析
這篇文章主要為大家介紹了Python使用中文文本處理利器jieba庫中的詞性標注和關(guān)鍵詞提取功能進行文本情感分析實例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-12-12

