Twisted UDP组播

在IPv4中有一个专用的地址方位被用于组播管理,即224.0.0.0~239.255.255.255。组播参与者(包括发送端、接收端)在实际收发数据之间需要加入该范围中的一个地址;之后组中的所有终端都可以使用UDP方式向组中的其他终端发消息。

DatagramProtocol

  • datagramReceived():接收到UDP报文后处理的事件

  • startProtocol():当Protocol实例被第一次作为参数传给listenMulticast()时调用

关键函数

  • DatagramProtocol.transport.leaveGroup():离开组播

  • DatagramProtocol.transport.joinGroup():加入组播

  • DatagramProtocol.transport.setTTL(5) :设置多播数据包的生存时间

# coding:utf8

from twisted.internet.protocol import DatagramProtocol
from twisted.internet import reactor

multicast_ip = '224.0.0.2'
port = 8001

class Multicast(DatagramProtocol):
    def startProtocol(self):
        '''
        加入组播(必须重新)
        :return: 
        '''
        self.transport.setTTL(5) # 设置多播数据包的生存时间
        self.transport.joinGroup(multicast_ip)
        self.transport.write('Notify'.encode('utf8'),(multicast_ip,port))

    def datagramReceived(self, datagram: bytes, addr):
        '''
        接收到组播发送的数据
        :param datagram: 
        :param addr: 
        :return: 
        '''
        print('Datagram %s received from %s '%(repr(datagram.decode('utf8')),repr(addr)))
        if datagram.decode('utf8') == 'Notify':
            self.transport.write('Acknowlege'.encode('utf8'),(multicast_ip,port))

    def closeConnection(self):
        '''
        自定义函数,离开组播时调用
        :return: 
        '''
        self.transport.leaveGroup()

reactor.listenMulticast(port,Multicast(),listenMultiple=True)
reactor.run()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值