網站首頁 編程語言 正文
介紹
asyncore庫是python的一個標準庫,提供了以異步的方式寫入套接字服務的客戶端和服務器的基礎結構。操作網絡的時候可以直接使用socket等底層的庫,但是asyncore使得我們可以更加方便的操作網絡,避免直接使用socket,select,poll等工具時需要面對的復雜情況。
1.定義類并且繼承 asyncore.dispatcher
class SocketClient(asyncore.dispatcher):
2.實現類中的回調代碼
調用父類方法
asyncore.dispatcher.__init__(self)
創建socket對象
self.create_socket()
連接服務器
address = (host, port)
self.connect(address)
實現 handle_connect 回調函數
當socket 連接服務器成功時回調該函數
def handle_connect(self):
print('連接成功')
實現 writable 回調函數
描述是否有數據需要被發送到服務器。返回值為True表示可寫,False 表示不可寫。
如果不識閑默認返回為 True,當返回True時,回調函數handle_write將被觸發
def writable(self):
return False
實現 handle_write 回調函數
當有數據需要發送時 (writable 回調函數返回 True時),
該函數被觸發,通常情況下在該函數中編寫send方法發送數據
def handle_write(self):
# 內部實現對服務器發送數據
# 調用 send 方法,參數是字節數據
self.send('hello world'.encode('utf-8'))
實現 readable 回調函數
描述是否有數據從服務端讀取。返回True標識有數據需要讀取,
False表示沒有數據需要被讀取,當不實現默認返回True,
當返回True時,handle_read將被觸發
def readable(self):
# 表示有數據需要讀取
return True
實現 handle_read回調函數
當有數據需要讀取時(readable 回調函數返回True時),
該函數被觸發,通常情況下在該函數中編寫recv方法接收數據
def handle_read(self):
# 主動讀取接收數據 參數是需要接收數據長度
result = self.recv(8000)
print(result)
實現 handle_error回調函數
當程序運行過程發生異常時回調
def handle_error(self):
# 編寫處理錯誤方法
t, e, trace = sys.exc_info()
print(t, e, trace)
實現 handle_close回調函數
當連接被關閉時觸發
def handle_close(self):
print('連接關閉')
# 執行關閉
self.close()
3.創建對象并且執行asyncore.loop進入運行循環
timeout為一次循環所用的時間,也就是超時時間。
client = SocketClient('127.0.0.1', 9000)
# 開始啟動運行循環
asyncore.loop(timeout=10)
服務端示例代碼
import asyncore
import socket
class EchoHandler(asyncore.dispatcher_with_send):
def handle_read(self):
data = self.recv(8192)
if data:
self.send(data)
class EchoServer(asyncore.dispatcher):
def __init__(self, host, port):
asyncore.dispatcher.__init__(self)
self.create_socket(socket.AF_INET, socket.SOCK_STREAM)
self.set_reuse_addr()
self.bind((host, port))
# 監聽連接參數指定排隊的最大連接數和應至少為1; 最大值取決于系統(通常為5)。
self.listen(5)
'''
當與發起對本地端點的 connect() 調用的新遠程端點已建立連接時會在偵聽通道(被動打開方)上被調用。
sock 是可被用于在連接上發送和接收數據的 新建 套接字對象,
而 addr 是綁定到連接另一端的套接字的地址。
'''
def handle_accept(self):
pair = self.accept()
if pair is not None:
sock, addr = pair
print('連接來自于 %s' % repr(addr))
# 連接成功后 給客戶端發送消息
handler = EchoHandler(sock)
handler.send('hello world'.encode('utf-8'))
if __name__ == '__main__':
server = EchoServer('127.0.0.1', 9000)
asyncore.loop()
運行結果
服務端:
客戶端:
注意
本文章使用python3.7版本,3.10版本已經移除此模塊,之后可使用asyncio模塊。
至此結束,本文章只做了一個基本使用講解,可以查看借鑒使用,若想要做消息還差的很多。
原文鏈接:https://blog.csdn.net/json_ligege/article/details/128389493
相關推薦
- 2022-07-03 Golang之空結構體和零長數組的實踐
- 2022-10-11 Windows下vs中對DLL、exe文件添加屬性信息
- 2022-03-25 Redis分布式鎖如何實現續期_Redis
- 2022-08-07 Go?gRPC教程實現Simple?RPC_Golang
- 2022-11-30 AMP?Tensor?Cores節省內存PyTorch模型詳解_python
- 2022-04-20 淺談C語言的變量和常量_C 語言
- 2021-12-06 c#二叉樹存儲介紹_C#教程
- 2022-12-22 React?Hooks?-?useContetx和useReducer的使用實例詳解_React
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支