Python使用socket實現(xiàn)組播與發(fā)送二進(jìn)制數(shù)據(jù)_第1頁
Python使用socket實現(xiàn)組播與發(fā)送二進(jìn)制數(shù)據(jù)_第2頁
Python使用socket實現(xiàn)組播與發(fā)送二進(jìn)制數(shù)據(jù)_第3頁
Python使用socket實現(xiàn)組播與發(fā)送二進(jìn)制數(shù)據(jù)_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

第Python使用socket實現(xiàn)組播與發(fā)送二進(jìn)制數(shù)據(jù)什么是組播

點對點連接可以處理很多通信需求,不過隨著直接連接數(shù)的增加,在多對通信方之間傳遞相同的消息會變得越來越困難。

單獨地向各個接收方發(fā)送消息會耗費額外的處理時間和帶寬,這對于諸如完成流視頻或音頻操作的應(yīng)用來說,代碼會出現(xiàn)顯著的性能問題。

而使用組播(multicast)向多個端點同時發(fā)送消息可以得到更好的效率,因為網(wǎng)絡(luò)基礎(chǔ)設(shè)施可以確保數(shù)據(jù)包會被傳送到所有接收方。

組播消息總是使用UDP發(fā)送,因為TCP需要提供一對通信系統(tǒng)。組播的地址被稱為組播組,這是常規(guī)的IPv4地址范圍的一個子集(224.0.0.0~230.255.255.255),專門為主播通信預(yù)留。

這些地址會由網(wǎng)絡(luò)路由器和交換機進(jìn)行特殊的處理,所以發(fā)送到組的消息可以在互聯(lián)網(wǎng)上被分發(fā)到加入這個組的所有接收方。

需要注意的是,大多數(shù)托管的路由器與交換機默認(rèn)會禁止組播通信。如果后續(xù)運行程序有問題,那么可以檢查你的網(wǎng)絡(luò)設(shè)置。

發(fā)送組播消息

由于無法知道會收到多少響應(yīng),所以需要對套接字使用一個超時值,以避免等待回答時無限阻塞。

TTL(Time-To-Livevalue)是一個生存時間值,會控制多少網(wǎng)絡(luò)接收這個數(shù)據(jù)包。要使用IP_MULTICAST_TTL選項與setsockopt()函數(shù)來設(shè)置TTL。默認(rèn)值1表示路由器不會把數(shù)據(jù)包轉(zhuǎn)發(fā)到當(dāng)前網(wǎng)段之外。TTL最大取值255,應(yīng)包包裝為1個字節(jié)。

示例代碼如下:

importsocket

importstruct

#1.創(chuàng)建一個套接字

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篇對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ī)的套接字并綁定到一個端口后,可以使用setsockopt()改變IP_ADD_MEMBERSHIP選項,增加安東組播組。

這個選項值是組播地址的一個8字節(jié)的打包表示,后面是服務(wù)器監(jiān)聽通信流的網(wǎng)絡(luò)接口,由其IP地址標(biāo)識。這里,接收者使用INADDR_ANY監(jiān)聽所有接口。

示例代碼如下:

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. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論