Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
00d7b498
提交
00d7b498
authored
1月 24, 2015
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
routing/dht: adjust routing table on peer conn/disc
上级
4ae01e7a
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
69 行增加
和
1 行删除
+69
-1
dht.go
routing/dht/dht.go
+9
-1
notif.go
routing/dht/notif.go
+33
-0
bucket.go
routing/kbucket/bucket.go
+10
-0
table.go
routing/kbucket/table.go
+17
-0
没有找到文件。
routing/dht/dht.go
浏览文件 @
00d7b498
...
...
@@ -65,9 +65,17 @@ func NewDHT(ctx context.Context, h host.Host, dstore ds.ThreadSafeDatastore) *Ip
dht
.
datastore
=
dstore
dht
.
self
=
h
.
ID
()
dht
.
peerstore
=
h
.
Peerstore
()
dht
.
ContextGroup
=
ctxgroup
.
WithContext
(
ctx
)
dht
.
host
=
h
// register for network notifs.
dht
.
host
.
Network
()
.
Notify
((
*
netNotifiee
)(
dht
))
dht
.
ContextGroup
=
ctxgroup
.
WithContextAndTeardown
(
ctx
,
func
()
error
{
// remove ourselves from network notifs.
dht
.
host
.
Network
()
.
StopNotify
((
*
netNotifiee
)(
dht
))
return
nil
})
// sanity check. this should **never** happen
if
len
(
dht
.
peerstore
.
Addresses
(
dht
.
self
))
<
1
{
panic
(
"attempt to initialize dht without addresses for self"
)
...
...
routing/dht/notif.go
0 → 100644
浏览文件 @
00d7b498
package
dht
import
(
inet
"github.com/jbenet/go-ipfs/p2p/net"
)
// netNotifiee defines methods to be used with the IpfsDHT
type
netNotifiee
IpfsDHT
func
(
nn
*
netNotifiee
)
DHT
()
*
IpfsDHT
{
return
(
*
IpfsDHT
)(
nn
)
}
func
(
nn
*
netNotifiee
)
Connected
(
n
inet
.
Network
,
v
inet
.
Conn
)
{
dht
:=
nn
.
DHT
()
select
{
case
<-
dht
.
Closing
()
:
return
}
dht
.
Update
(
dht
.
Context
(),
v
.
RemotePeer
())
}
func
(
nn
*
netNotifiee
)
Disconnected
(
n
inet
.
Network
,
v
inet
.
Conn
)
{
dht
:=
nn
.
DHT
()
select
{
case
<-
dht
.
Closing
()
:
return
}
dht
.
routingTable
.
Remove
(
v
.
RemotePeer
())
}
func
(
nn
*
netNotifiee
)
OpenedStream
(
n
inet
.
Network
,
v
inet
.
Stream
)
{}
func
(
nn
*
netNotifiee
)
ClosedStream
(
n
inet
.
Network
,
v
inet
.
Stream
)
{}
routing/kbucket/bucket.go
浏览文件 @
00d7b498
...
...
@@ -30,6 +30,16 @@ func (b *Bucket) find(id peer.ID) *list.Element {
return
nil
}
func
(
b
*
Bucket
)
remove
(
id
peer
.
ID
)
{
b
.
lk
.
RLock
()
defer
b
.
lk
.
RUnlock
()
for
e
:=
b
.
list
.
Front
();
e
!=
nil
;
e
=
e
.
Next
()
{
if
e
.
Value
.
(
peer
.
ID
)
==
id
{
b
.
list
.
Remove
(
e
)
}
}
}
func
(
b
*
Bucket
)
moveToFront
(
e
*
list
.
Element
)
{
b
.
lk
.
Lock
()
b
.
list
.
MoveToFront
(
e
)
...
...
routing/kbucket/table.go
浏览文件 @
00d7b498
...
...
@@ -87,6 +87,23 @@ func (rt *RoutingTable) Update(p peer.ID) peer.ID {
return
""
}
// Remove deletes a peer from the routing table. This is to be used
// when we are sure a node has disconnected completely.
func
(
rt
*
RoutingTable
)
Remove
(
p
peer
.
ID
)
{
rt
.
tabLock
.
Lock
()
defer
rt
.
tabLock
.
Unlock
()
peerID
:=
ConvertPeerID
(
p
)
cpl
:=
commonPrefixLen
(
peerID
,
rt
.
local
)
bucketID
:=
cpl
if
bucketID
>=
len
(
rt
.
Buckets
)
{
bucketID
=
len
(
rt
.
Buckets
)
-
1
}
bucket
:=
rt
.
Buckets
[
bucketID
]
bucket
.
remove
(
p
)
}
func
(
rt
*
RoutingTable
)
nextBucket
()
peer
.
ID
{
bucket
:=
rt
.
Buckets
[
len
(
rt
.
Buckets
)
-
1
]
newBucket
:=
bucket
.
Split
(
len
(
rt
.
Buckets
)
-
1
,
rt
.
local
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论