电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Python Socket編程詳解

瀏覽:6日期:2022-06-21 11:19:00
背景

關于Python Socket編程,首先需要了解幾個計算機網絡的知識,通過以下的幾個問題,有助于更好的理解Socket編程的意義,以及整個框架方面的知識:

TCP和UDP協議本質上的區別?

TCP協議,面向連接,可靠,基于字節流的傳輸層通信協議;UDP協議無連接,不可靠,基于數據包的傳輸層協議。

TCP協議在建立連接的過程需要經歷三次握手,斷開連接則需要經歷四次揮手,而這建立連接的過程增加了傳輸過程中的安全性。而建立連接的過程則會消耗系統的資源,消耗更多的時間,而相比較UDP協議傳輸過程則不會出現這種問題。

總結來講,基于TCP協議傳輸,需要不斷的確認對方是否收到信息,從而建立連接(確認過程次數有限制,即三次握手),UDP協議傳輸則不需要確認接收端是否收到信息,只需要將信息發給對方。

TCP/IP協議棧、HTTP協議、Socket之間的區別和聯系?

TCP/IP協議棧就是一系列網絡協議,可以分為四層模型來分析:應用層、傳輸層、網絡層、鏈路層;

HTTP協議(超文本傳輸協議)就是在這一協議棧中的應用層協議;HTTP協議簡單來說,它的作用就是規范數據的格式,讓程序能夠方便的識別,并且收發雙方都需要遵循同樣的協議格式進行數據傳輸。(應用層的協議也和HTTP協議的作用類似,不一樣的是定義不同的數據格式。)

Socket可以理解為TCP/IP協議棧提供的對外的操作接口,即應用層通過網絡協議進行通信的接口。Socket可以使用不同的網絡協議進行端對端的通信;

TCP Socket服務器的通信過程?

Server端:

建立連接(socket()函數創建socket描述符、bind()函數綁定特定的監聽地址(ip+port)、listen()函數監聽socket、accept()阻塞等待客戶端連接)

數據交互(read()函數阻塞等待客戶端發送數據、write()函數發送給客戶端數據)

Client端:

建立連接(socket()函數創建socket描述符、connect()函數向指定的監聽地址發送連接請求)

數據交互(wirte()函數發送服務端數據、read()函數足阻塞等待接受服務端發送的數據)

socket和websocket之間的聯系?

webosocket是一種通信協議,不同于HTTP請求,客戶端請求服務端資源,服務端響應的通信過程;websocket允許服務端主動向客戶端推送消息,同時做到客戶端和服務端雙向通訊的協議。(具體底層原理有待后面實踐,暫時未接觸)

HTTP,WSGI協議的聯系和區別?

HTTP協議(超文本傳輸協議),屬于TCP/IP協議棧中應用層的協議。用于規范傳輸數據的格式,是一種客戶端和服務端傳輸的規則。

WSGI協議則是Python定義的Web服務器和框架程序通信的接口規則。兩者聯系不大,強行說的話,Python框架程序主要處理的是HTTP請求。

(后期可以實現一個WSGI協議的Python框架,用于處理HTTP請求的實驗。)

主流Web框架,異步Web框架?

主流Web框架:Django、Flask

異步Web框架:Tornado(內置異步模塊)、Snaic(Python自帶asyncio)、FastAPI(基于Starlette庫) 、aiohttp(基于asyncio)

asyncio,aiohttp之間的聯系?(異步編程)

asyncio是一個異步IO庫,aiohttp就是基于asyncio的異步HTTP框架(支持客戶端/服務端)

代碼設計

Python提供了基本的socket模塊:

socket模塊;提供了標準的BSD Sockets API; socketserver模塊:提供了服務器中心類,簡化服務器的開發; TCP Socket服務端

socket模塊:

# -*- coding: utf-8 -*-from socket import socket, AF_INET, SOCK_STREAMdef echo_handler(sock ,address):print('Get Connection from address:', address)while True:response = sock.recv(8192)if not response:breakprint(f'Got {response}')sock.sendall(response)def echo_server(address, back_log=5):sock = socket(AF_INET, SOCK_STREAM)sock.bind(address)sock.listen(back_log)while True:sock_client, address = sock.accept()echo_handler(sock_client, address)if __name__ == '__main__':echo_server((’localhost’, 5000))

代碼詳解:

創建一個基于IPV4和TCP協議的Socket,這里AF_INET指的是使用IPV4協議,SOCK_STREAM指定使用面向流的TCP協議,綁定監聽端口,設置等待連接的最大數量 創建一個永久循環,獲取客戶端請求的連接,accept()會等待并返回一個客戶端的連接; 連接建立后,等待客戶端數據,接受完客戶端數據,然后返回數據給客戶端,最后關閉連接

存在的問題:當出現多個客戶端請求時,由于是單個線程會發生阻塞的情況,所以如果需要多線程處理多個客戶端請求,可以這樣改;

from threading import Threadwhile True:client_sock, address = sock.accept()thread = Thread(target=echo_handler, args=(client_sock, address))thread.start()

這樣的話,就會在每個客戶端請求的時候,生成一個子線程然后處理請求;(但是存在一個問題:當突然大量請求連接,消耗系統資源達到上限后,很可能造成程序無法處理后續請求。)

socketserver模塊:

from socketserver import BaseRequestHandler, TCPServerclass EchoHandler(BaseRequestHandler): def handle(self):print('Got Connection From: %s' % str(self.client_address))while True: msg = self.request.recv(8192) if not msg:break self.request.send(msg)if __name__ == '__main__': server = TCPServer(('', 5000), EchoHandler) server.serve_forever()

from socketserver import StreamRequestHandler, TCPServer, ThreadingTCPServerimport timeclass EchoHandler(StreamRequestHandler): def handle(self):print('Got Connection Address: %s' % str(self.client_address))for line in self.rfile: print(line) self.wfile.write(bytes('hello {}'.format(line.decode(’utf-8’)).encode(’utf-8’)))if __name__ == '__main__': serv = ThreadingTCPServer(('', 5000), EchoHandler) serv.serve_forever()

代碼詳解:

處理多個客戶端,初始化一個ThreadingTCPServer實例; 設置綁定的IP地址和端口,以及處理類; 使用StreamRequestHandler(使用流的請求處理程序類,類似file-like對象,提供標準文件接口簡化通信過程),重寫里面的handle方法,獲取請求數據,返回數據給客戶端; TCP Socket客戶端

socket模塊:

# -*- coding: utf-8 -*-from socket import socket, AF_INET, SOCK_STREAMimport timedef request_handler():start_time = time.time()sock_client = socket(AF_INET, SOCK_STREAM)sock_client.connect((’localhost’, 5000))book_content = ''with open('send_books.txt', 'r') as f:book_content = f.read()content_list = book_content.split('n')for content in content_list:if content:sock_client.send((content).encode())time.sleep(2)response = sock_client.recv(8192)print(response)end_time = time.time()print('總共耗時:', end_time-start_time)if __name__ == '__main__':request_handler()UDP Socket

Socket模塊:

from socket import socket, AF_INET, SOCK_DGRAMimport timedef time_server(address): sock = socket(AF_INET, SOCK_DGRAM) sock.bind(address) while True:msg, addr = sock.recvfrom(8192)print(’Get message from’, addr)resp = time.ctime()sock.sendto(resp.encode(’ascii’), addr)if __name__ == '__main__': time_server((’’, 5000))

代碼不詳解,和之前的差不多,注意不同的協議就完事了

客戶端測試:

from socket import socket, AF_INET, SOCK_DGRAMif __name__ == '__main__': s = socket(AF_INET, SOCK_DGRAM) s.sendto(b’hello’, (’localhost’, 5000)) text = s.recvfrom(8192) print(text)

socketserver模塊:

from socketserver import BaseRequestHandler, UDPServerimport timeclass TimeHandler(BaseRequestHandler): def handle(self):print('Got Connection %s'.format(str(self.client_address)))data = self.request[0]print(data)msg, sock = self.requestprint(msg)data = time.ctime()sock.sendto(data.encode(’ascii’), self.client_address)if __name__ == '__main__': u = UDPServer(('localhost', 9999), TimeHandler) u.serve_forever()

代碼不在贅述,如果需要多線程處理并發操作可以使用ThreadingUDPServer

總結

關于本篇介紹Python Socket編程,大都是皮毛,只是談到了Python實際處理socket的幾個模塊,關于socket底層方面的知識并未提及,先了解個大概,從實際使用方面出發,在實際使用過程中結合計算機網絡知識,能夠對socket在整個TCP/IP協議棧中的作用。

socket和socketserver模塊都可以用來編寫網絡程序,不同的是socketserver省事很多,你可以專注業務邏輯,不用去理會socket的各種細節,包括不限于多線程/多進程,接收數據,發送數據,通信過程。

以上就是Python Socket編程詳解的詳細內容,更多關于Python Socket編程的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 山东成考网-山东成人高考网 | 吨袋包装机|吨包秤|吨包机|集装袋包装机-烟台华恩科技 | 全国冰箱|空调|洗衣机|热水器|燃气灶维修服务平台-百修家电 | 九州网址_专注于提供网址大全分享推广中文网站导航服务 | 一体化污水处理设备_生活污水处理设备_全自动加药装置厂家-明基环保 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 直流电能表-充电桩电能表-导轨式电能表-智能电能表-浙江科为电气有限公司 | 自清洗过滤器,浅层砂过滤器,叠片过滤器厂家-新乡市宇清净化 | 工控机-工业平板电脑-研华工控机-研越无风扇嵌入式box工控机 | 正压送风机-多叶送风口-板式排烟口-德州志诺通风设备 | 小型手持气象站-空气负氧离子监测站-多要素微气象传感器-山东天合环境科技有限公司 | 超声骨密度仪-骨密度检测仪-经颅多普勒-tcd仪_南京科进实业有限公司 | 防爆电机_ybx3系列电机_河南省南洋防爆电机有限公司 | 智能交通网_智能交通系统_ITS_交通监控_卫星导航_智能交通行业 | 浙江寺庙设计-杭州寺院设计-宁波寺庙规划_汉匠| 信阳网站建设专家-信阳时代网联-【信阳网站建设百度推广优质服务提供商】信阳网站建设|信阳网络公司|信阳网络营销推广 | 传递窗_超净|洁净工作台_高效过滤器-传递窗厂家广州梓净公司 | 东莞压铸厂_精密压铸_锌合金压铸_铝合金压铸_压铸件加工_东莞祥宇金属制品 | 蔡司三坐标-影像测量机-3D扫描仪-蔡司显微镜-扫描电镜-工业CT-ZEISS授权代理商三本工业测量 | 卷筒电缆-拖链电缆-特种柔性扁平电缆定制厂家「上海缆胜」 | 房车价格_依维柯/大通/东风御风/福特全顺/江铃图片_云梯搬家车厂家-程力专用汽车股份有限公司 | 黑龙江「京科脑康」医院-哈尔滨失眠医院_哈尔滨治疗抑郁症医院_哈尔滨精神心理医院 | 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | 范秘书_懂你的范文小秘书 | 对辊式破碎机-对辊制砂机-双辊-双齿辊破碎机-巩义市裕顺机械制造有限公司 | 代办建筑资质升级-建筑资质延期就找上海国信启航 | 北京网站建设公司_北京网站制作公司_北京网站设计公司-北京爱品特网站建站公司 | 广州展览制作|展台制作工厂|展览设计制作|展览展示制作|搭建制作公司 | 北京征地律师,征地拆迁律师,专业拆迁律师,北京拆迁律师,征地纠纷律师,征地诉讼律师,征地拆迁补偿,拆迁律师 - 北京凯诺律师事务所 | 比亚迪叉车-比亚迪电动叉车堆垛车托盘车仓储叉车价格多少钱报价 磁力去毛刺机_去毛刺磁力抛光机_磁力光饰机_磁力滚抛机_精密金属零件去毛刺机厂家-冠古科技 | 水冷式工业冷水机组_风冷式工业冷水机_水冷螺杆冷冻机组-深圳市普威机械设备有限公司 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 并离网逆变器_高频UPS电源定制_户用储能光伏逆变器厂家-深圳市索克新能源 | 塑料熔指仪-塑料熔融指数仪-熔体流动速率试验机-广东宏拓仪器科技有限公司 | 大型果蔬切片机-水果冬瓜削皮机-洗菜机切菜机-肇庆市凤翔餐饮设备有限公司 | 粤丰硕水性环氧地坪漆-防静电自流平厂家-环保地坪涂料代理 | 都江堰招聘网-都江堰人才网 都江堰人事人才网 都江堰人才招聘网 邢台人才网_邢台招聘网_邢台123招聘【智达人才网】 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 深圳标识制作公司-标识标牌厂家-深圳广告标识制作-玟璟广告-深圳市玟璟广告有限公司 |