



下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第Python使用socket實(shí)現(xiàn)組播與發(fā)送二進(jìn)制數(shù)據(jù)什么是組播
點(diǎn)對(duì)點(diǎn)連接可以處理很多通信需求,不過(guò)隨著直接連接數(shù)的增加,在多對(duì)通信方之間傳遞相同的消息會(huì)變得越來(lái)越困難。
單獨(dú)地向各個(gè)接收方發(fā)送消息會(huì)耗費(fèi)額外的處理時(shí)間和帶寬,這對(duì)于諸如完成流視頻或音頻操作的應(yīng)用來(lái)說(shuō),代碼會(huì)出現(xiàn)顯著的性能問(wèn)題。
而使用組播(multicast)向多個(gè)端點(diǎn)同時(shí)發(fā)送消息可以得到更好的效率,因?yàn)榫W(wǎng)絡(luò)基礎(chǔ)設(shè)施可以確保數(shù)據(jù)包會(huì)被傳送到所有接收方。
組播消息總是使用UDP發(fā)送,因?yàn)門CP需要提供一對(duì)通信系統(tǒng)。組播的地址被稱為組播組,這是常規(guī)的IPv4地址范圍的一個(gè)子集(224.0.0.0~230.255.255.255),專門為主播通信預(yù)留。
這些地址會(huì)由網(wǎng)絡(luò)路由器和交換機(jī)進(jìn)行特殊的處理,所以發(fā)送到組的消息可以在互聯(lián)網(wǎng)上被分發(fā)到加入這個(gè)組的所有接收方。
需要注意的是,大多數(shù)托管的路由器與交換機(jī)默認(rèn)會(huì)禁止組播通信。如果后續(xù)運(yùn)行程序有問(wèn)題,那么可以檢查你的網(wǎng)絡(luò)設(shè)置。
發(fā)送組播消息
由于無(wú)法知道會(huì)收到多少響應(yīng),所以需要對(duì)套接字使用一個(gè)超時(shí)值,以避免等待回答時(shí)無(wú)限阻塞。
TTL(Time-To-Livevalue)是一個(gè)生存時(shí)間值,會(huì)控制多少網(wǎng)絡(luò)接收這個(gè)數(shù)據(jù)包。要使用IP_MULTICAST_TTL選項(xiàng)與setsockopt()函數(shù)來(lái)設(shè)置TTL。默認(rèn)值1表示路由器不會(huì)把數(shù)據(jù)包轉(zhuǎn)發(fā)到當(dāng)前網(wǎng)段之外。TTL最大取值255,應(yīng)包包裝為1個(gè)字節(jié)。
示例代碼如下:
importsocket
importstruct
#1.創(chuàng)建一個(gè)套接字
sock=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
multicast_group=('224.3.29.71',10000)
sock.settimeout(10)
ttl=struct.pack('b',1)#本博主數(shù)據(jù)結(jié)構(gòu)與算法第10篇對(duì)struct二進(jìn)制結(jié)構(gòu)體進(jìn)行介紹
sock.setsockopt(socket.IPPROTO_IP,socket.IP_MULTICAST_TTL,ttl)
msg="群發(fā)的消息,你不必回".encode('UTF-8')
sent=sock.sendto(msg,multicast_group)
whileTrue:
try:
data,server=sock.recvfrom(1024)
exceptsocket.timeout:
print('timeout')
break
else:
print(data,server)
finally:
sock.close()
這里的代碼與UDP類似,除了sock.setsockopt()的調(diào)用。
接收組播消息
建立組播接收者的第一步是創(chuàng)建UDP套接字。創(chuàng)建常規(guī)的套接字并綁定到一個(gè)端口后,可以使用setsockopt()改變IP_ADD_MEMBERSHIP選項(xiàng),增加安東組播組。
這個(gè)選項(xiàng)值是組播地址的一個(gè)8字節(jié)的打包表示,后面是服務(wù)器監(jiān)聽(tīng)通信流的網(wǎng)絡(luò)接口,由其IP地址標(biāo)識(shí)。這里,接收者使用INADDR_ANY監(jiān)聽(tīng)所有接口。
示例代碼如下:
importsocket
importstruct
multicast_group='224.3.29.71'
server_address=('',10000)
sock=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
sock.bind(server_address)
group=socket.inet_aton(multicast_group)
mreq=struct.pack('4sL',group,socket.INADDR_ANY)
sock.setsockopt(socket.IPPROTO_IP,socket.IP_ADD_MEMBERSHIP,mreq)
whileTrue:
data,address=sock.recvfrom(1024)
print(data.decode('UTF-8'),a
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025春季學(xué)期國(guó)家開(kāi)放大學(xué)??啤队變簣@課程基礎(chǔ)》一平臺(tái)在線形考形成性考核作業(yè)試題及答案
- 醫(yī)院醫(yī)務(wù)人員禮儀培訓(xùn)體系構(gòu)建與實(shí)踐
- 【培訓(xùn)課件】高級(jí)生產(chǎn)管理與優(yōu)化策略研討會(huì)
- 民政救助協(xié)議書(shū)
- 兼職人員勞務(wù)合同
- 浴池消毒協(xié)議書(shū)
- 木材訂購(gòu)協(xié)議書(shū)
- 游艇包船協(xié)議書(shū)
- 委托代理合同補(bǔ)充協(xié)議
- 醫(yī)療質(zhì)量核心制度培訓(xùn)
- 上海市市轄區(qū)(2024年-2025年小學(xué)五年級(jí)語(yǔ)文)人教版期末考試(下學(xué)期)試卷及答案
- 2024年-2025年公路養(yǎng)護(hù)工理論知識(shí)考試題及答案
- 建筑施工安全檢查標(biāo)準(zhǔn)JGJ59-2011
- 動(dòng)物健康數(shù)據(jù)挖掘
- 水泵采購(gòu)?fù)稑?biāo)方案(技術(shù)方案)
- 《客艙設(shè)備與服務(wù)》課件-3.客艙服務(wù)
- 2023學(xué)校幼兒園懷舊“六一兒童節(jié)”(時(shí)光不老追憶童年)主題游園活動(dòng)策劃案-47P
- Carrousel2000氧化溝系統(tǒng)設(shè)計(jì)說(shuō)明書(shū)
- (高清版)DZT 0347-2020 礦山閉坑地質(zhì)報(bào)告編寫規(guī)范
- 部編版語(yǔ)文二年級(jí)下冊(cè)第四單元整體教學(xué)設(shè)計(jì)教案
- 藥學(xué)實(shí)踐教學(xué)設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論