Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
647da1bd
提交
647da1bd
authored
1月 16, 2015
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #582 from jbenet/addr-explosion
addr-explosion mitigated adding
上级
f78d4141
c057cea6
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
14 行增加
和
5 行删除
+14
-5
ipfs_impl.go
exchange/bitswap/network/ipfs_impl.go
+3
-1
handlers.go
routing/dht/handlers.go
+2
-2
query.go
routing/dht/query.go
+5
-0
routing.go
routing/dht/routing.go
+4
-2
没有找到文件。
exchange/bitswap/network/ipfs_impl.go
浏览文件 @
647da1bd
...
...
@@ -112,7 +112,9 @@ func (bsnet *impl) FindProvidersAsync(ctx context.Context, k util.Key, max int)
defer
close
(
out
)
providers
:=
bsnet
.
routing
.
FindProvidersAsync
(
ctx
,
k
,
max
)
for
info
:=
range
providers
{
bsnet
.
host
.
Peerstore
()
.
AddAddresses
(
info
.
ID
,
info
.
Addrs
)
if
info
.
ID
!=
bsnet
.
host
.
ID
()
{
// dont add addrs for ourselves.
bsnet
.
host
.
Peerstore
()
.
AddAddresses
(
info
.
ID
,
info
.
Addrs
)
}
select
{
case
<-
ctx
.
Done
()
:
return
...
...
routing/dht/handlers.go
浏览文件 @
647da1bd
...
...
@@ -236,9 +236,9 @@ func (dht *IpfsDHT) handleAddProvider(ctx context.Context, p peer.ID, pmes *pb.M
}
log
.
Infof
(
"received provider %s for %s (addrs: %s)"
,
p
,
key
,
pi
.
Addrs
)
for
_
,
maddr
:=
range
pi
.
Addrs
{
if
pi
.
ID
!=
dht
.
self
{
// dont add own addrs.
// add the received addresses to our peerstore.
dht
.
peerstore
.
Add
Address
(
p
,
maddr
)
dht
.
peerstore
.
Add
PeerInfo
(
pi
)
}
dht
.
providers
.
AddProvider
(
key
,
p
)
}
...
...
routing/dht/query.go
浏览文件 @
647da1bd
...
...
@@ -254,6 +254,11 @@ func (r *dhtQueryRunner) queryPeer(cg ctxgroup.ContextGroup, p peer.ID) {
}
else
if
len
(
res
.
closerPeers
)
>
0
{
log
.
Debugf
(
"PEERS CLOSER -- worker for: %v (%d closer peers)"
,
p
,
len
(
res
.
closerPeers
))
for
_
,
next
:=
range
res
.
closerPeers
{
if
next
.
ID
==
r
.
query
.
dht
.
self
{
// dont add self.
log
.
Debugf
(
"PEERS CLOSER -- worker for: %v found self"
,
p
)
continue
}
// add their addresses to the dialer's peerstore
r
.
query
.
dht
.
peerstore
.
AddPeerInfo
(
next
)
r
.
addPeerToQuery
(
cg
.
Context
(),
next
.
ID
)
...
...
routing/dht/routing.go
浏览文件 @
647da1bd
...
...
@@ -223,8 +223,10 @@ func (dht *IpfsDHT) closerPeersSingle(ctx context.Context, key u.Key, p peer.ID)
var
out
[]
peer
.
ID
for
_
,
pbp
:=
range
pmes
.
GetCloserPeers
()
{
pid
:=
peer
.
ID
(
pbp
.
GetId
())
dht
.
peerstore
.
AddAddresses
(
pid
,
pbp
.
Addresses
())
out
=
append
(
out
,
pid
)
if
pid
!=
dht
.
self
{
// dont add self
dht
.
peerstore
.
AddAddresses
(
pid
,
pbp
.
Addresses
())
out
=
append
(
out
,
pid
)
}
}
return
out
,
nil
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论