• 实现upnp ssdp来查找局域网内的其他节点


    upnp协议常用于一些智能家居产品中,这些产品连上家里局域网后,用同样连入家中局域网的手机就能很快检测到此产品了。在区块链技术中,upnp也被应用于寻找同一局域网内的其他节点。

    关于upnp的具体描述,这篇文章有很好的介绍,Exploring UPnP with Python,欢迎移步查看。我在这里粗略的介绍下。upnp里面有好几种具体的实现方式,这里介绍下用的最多的ssdp。ssdp一般有服务器端和客户端。服务器端会使用udp监听端口1900的广播信息,如果信息里面有“M-SEARCH”开头的字段,就会回复自己的产品信息,也就是被找到了。而客户端程序就会在局域网内发送端口1900的udp广播信息,来寻找服务器。具体到区块链中,一个节点实例既运行ssdp的服务器程序,也运行ssdp的客户端程序,这样这个节点既能找到局域网内的其他节点,也能被其他节点找到。

    在用到upnp的时候还有个功能常被用到,就是nat port forwarding,把局域网内的本地端口绑定到路由器上的端口,使运行在局域网内的程序能够转化为在公网上能够互相通信的程序了。这样,互联网上的其他的节点就能根据节点列表主动连接处于局域网内的节点了。它的代码基本逻辑是处于局域网内的程序首先使用upnp协议寻找到局域网的路由器,然后这个路由器必须要有nat port forwarding的功能,然后程序就能调用路由器的这个功能,把本地端口绑定到路由器的外部端口。

    我根据文章实现了一个ssdp的python程序,tw7613781/ssdp_upnp,也上传到了pypi,大家使用下面命令就能按照包文件,使用这个程序。考虑到他们是会阻塞线程的,在具体实现的时候,我让这两个class都继承了thread.Threading类,让他俩跑到自己的子线程去,然后使用线程安全的python内置queue来通信。既客户端类找到其他节点后把节点ip,port信息写到queue里,然后主线程能在queue读到这个信息,然后进行自己的业务逻辑。

    pip install ssdp-upnp
  • 相关阅读:
    AC日记——[ZJOI2012]网络 bzoj 2816
    [USACO08FEB]酒店Hotel 线段树
    divisors 数学
    Count on a tree 树上主席树
    STL备忘
    [TJOI2013]松鼠聚会 曼哈顿距离
    斐波那契数列 矩阵乘法优化DP
    [TJOI2013]奖学金 乱搞
    铁轨 清北学堂 线段树
    P3939 数颜色 线段树动态开点
  • 原文地址:https://www.cnblogs.com/wtang/p/10010537.html
Copyright © 2020-2023  润新知