IPFS0.5改进内容路由处理不可连接节点

OKX欧易app

OKX欧易app

欧易交易所app是全球排名第一的虚拟货币交易所,注册领取6万元盲盒礼包!

APP下载   官网注册
币安app

binance币安交易所

币安交易所app是全球排名第一的虚拟货币交易所,注册领取盲盒礼包!

APP下载   官网注册

在之前的分享中,我们提到在IPFS0.5版本中,DHT有了较大的改进,并简要介绍了DHT在IPFS中的作用以及其在IPFS中的实现方式:Kademlia。

今天我们介绍Kademlia如何处理无法连接的对等节点。

在之前的文章中我们介绍到Kademlia的主要特性是所有的对等节点都可以由小到大被内联集成起来,这个特性非常重要。

举例来说,当对等节点0在寻找对等节点55的一路寻址过程中,它一边找会一边知道自己离目标越来越近。要做到这一点,系统中的每个节点都要能互相通信,告知对方自己的身份。

如果在这个过程中节点0找到节点33,并要节点33告知下一个节点时,节点33却告知节点0一个已经无法连接通信的节点,那节点0再走下去就是个死胡同了,这不仅会导致网速变慢,还会导致全网数据的碎片化(有些节点可以连接而另一些节点无法连接)。

在系统中,节点间无法连接通信听起来有些奇怪,但通常有两个因素会导致这个情况发生:一个是网络地址的翻译(NetworkAddressTranslation,简称NAT),另一个是防火墙。

比如在几个非对称网络中有节点X、Y、Z,他们相互之间能互通并与A也相联结,但A却无法联通X、Y、Z。同样,如果节点A和B有网络地址翻译方面的问题,它们也无法相互连接通信。

当IPFS网络在2019年增长了30倍后,我们碰到了一个很大的问题:突然间IPFS DHT表中的很多节点都出现了网络地址翻译的问题,这导致很多节点无法连接,从而使得整个系统的质量极大降低。

为了处理这个问题,我们现在采用的办法是如果有节点被怀疑无法连接,就直接忽略这个节点,并且也鼓励一些节点自己退出系统,如果它们自己怀疑自己可能无法被其它节点连接了。

为了做到这点,我们使用了libp2p的AutoNAT功能,它类似一个分布式STUN层,让节点告知系统中其它节点自己的网络地址以及自己是否可以被连接。

只有一个节点可以被连接它才从客户模式(clientmode,在客户模式中节点可以向DHT表格发送查询请求,但无法对查询请求作出回应)切换为服务器模式(servermode,在服务器模式中节点既可以向DHT表格发送查询请求,也可以对查询请求作出回应)。

同理,如果一个服务器发现自己无法被其它节点连接了,它就会从服务器模式切换回客户模式。

AutoNAT功能以前只在某些节点中被激活。但AutoNAT的功能使用得越来越多,它帮助了我们清理系统中无法连接的节点,这使得AutoNAT的使用越来越呈现分布式状况。

因此,我们现在在所有的IPFS节点中都提供了AutoNAT功能,不过这个AutoNAT功能有一定的限制。

注意:节点在客户模式和服务器模式之间的自动切换是默认的配置选项。但用户也可以将节点固定设置为客户模式。

不过如果不将该选项设置为"dht"(自动切换模式)或"dhtclient"(固定设置为客户模式)则可能极大降低系统的性能。因此对此选项的设置一定要小心。

基于AutoNAT的模式切换非常有用,我们希望尽量用它把系统中无法再连接的节点清除掉。

为了谨慎起见,一个节点必须要验证它是否可公开被连接,如果它被验证既支持客户模式也支持服务器模式则它就可以被加入到DHT表中作为节点。

参考链接:https://blog.ipfs.io/2020-07-20-dht-deep-dive/

本站所有软件信息均由用户上传发布,版权归原著所有。如有侵权/违规内容,敬请来信告知邮箱:764327034@qq.com,我们将及时撤销! 转载请注明出处:https://czxurui.com/zx/63194.html

打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023年08月18日
下一篇 2023年08月18日

相关推荐

  • 达世币如何解锁节点,虚拟币达世币下线后原有的币子怎么办

    一、区块链信息如何传递区块链+即时通讯是怎样的?区块链特点之一就是通过分布式账本技术实现不可逆,同时采用各种技术,比如环签名、零知识证明等实现匿名、保护隐私等。社交网络由Facebook垄断、即时通讯由WhatsApp等中心化产品垄断,它们给用户带来了无与伦比的沟通方便,

    2025-04-05 09:00:01
    26 0
  • 比特币有多少节点,比特币有多少区块链

    一、比特币一共有多少个2100万个比特币(BitCoin)的概念最初由中本聪在2009年提出,根据中本聪的思路设计发布的开源软件以及建构其上的P2P网络。比特币是一种P2P形式的数字货币。点对点的传输意味着一个去中心化的支付系统。比特币不是无限量发行的,与大多数的货币不相同。

    2025-04-03 17:00:02
    24 0
  • 比特币 多少全节点,区块链节点有多少

    一、比特币一共有多少个2100万个比特币(BitCoin)的概念最初由中本聪在2009年提出,根据中本聪的思路设计发布的开源软件以及建构其上的P2P网络。比特币是一种P2P形式的数字货币。点对点的传输意味着一个去中心化的支付系统。比特币不是无限量发行的,与大多数的货币不相同。

    2025-04-03 05:30:01
    19 0
  • 比特币钱包全节点 多少gb,比特币节点是什么

    一、比特币的闪电节点有多少个据1ML数据,当前比特币闪电网络节点数量达到18061个,过去30天内增加7.30%;通道数量为40065个,过去30天内增加5.9%;网络容量达到1154个BTC,过去30天内增加6%。btc链乔教育在线旗下学硕创新区块链技术工作站是中国教育部学校规划建设发展中心开

    2025-03-31 05:00:01
    16 0
  • 达世币的主节点是什么,区块链项目中的达世币Dash是什么

    一、区块链项目中的达世币Dash是什么达世币是匿名币类区块链项目的典型代表之一,不仅如此,达世币还可以用即时支付实现秒到账,它是如何实现的呢?达世币诞生于2014年1月18日,匿名程度较比特币更高。达世币有三种转账方式,一是像比特币一样的普通转账;二是即时交易。不需

    2025-03-30 19:30:01
    17 0
  • 区块链最长多少节点,区块链节点有多少

    一、区块链节点有多少btc节点数量据Bitnodes统计,比特币区块链上的“可达节点”目前为10208个。在比特币节点数量排行中,美国所占数量最多,为2483个,达到24.32%。中国排名第五,数量为454个。区块链网络中的节点包括区块链网络中的节点包括手机、矿机和服务器等等。节点指

    2025-03-30 05:00:01
    17 0

发表回复

8206
验证码

评论列表(0条)

    暂无评论

ok交易所
已有100万用户加入ok交易所

立即下载