Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
cfbe92bc
提交
cfbe92bc
authored
12月 15, 2014
作者:
Jeromy
提交者:
Juan Batiz-Benet
12月 17, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rewrite sendWantlistToProviders
上级
946d2a96
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
66 行增加
和
83 行删除
+66
-83
bitswap.go
exchange/bitswap/bitswap.go
+15
-37
routing.go
routing/dht/routing.go
+3
-2
util.go
routing/dht/util.go
+0
-44
peerset.go
util/peerset/peerset.go
+48
-0
没有找到文件。
exchange/bitswap/bitswap.go
浏览文件 @
cfbe92bc
...
...
@@ -19,6 +19,7 @@ import (
peer
"github.com/jbenet/go-ipfs/peer"
u
"github.com/jbenet/go-ipfs/util"
eventlog
"github.com/jbenet/go-ipfs/util/eventlog"
pset
"github.com/jbenet/go-ipfs/util/peerset"
)
var
log
=
eventlog
.
Logger
(
"bitswap"
)
...
...
@@ -204,57 +205,34 @@ func (bs *bitswap) sendWantListTo(ctx context.Context, peers <-chan peer.Peer) e
}
func
(
bs
*
bitswap
)
sendWantlistToProviders
(
ctx
context
.
Context
,
wantlist
*
wl
.
Wantlist
)
{
provset
:=
make
(
map
[
u
.
Key
]
peer
.
Peer
)
provcollect
:=
make
(
chan
peer
.
Peer
)
ctx
,
cancel
:=
context
.
WithCancel
(
ctx
)
defer
cancel
()
wg
:=
sync
.
WaitGroup
{}
message
:=
bsmsg
.
New
()
message
.
SetFull
(
true
)
for
_
,
e
:=
range
bs
.
wantlist
.
Entries
()
{
message
.
AddEntry
(
e
.
Value
,
e
.
Priority
,
false
)
}
ps
:=
pset
.
NewPeerSet
()
// Get providers for all entries in wantlist (could take a while)
wg
:=
sync
.
WaitGroup
{}
for
_
,
e
:=
range
wantlist
.
Entries
()
{
wg
.
Add
(
1
)
go
func
(
k
u
.
Key
)
{
defer
wg
.
Done
()
child
,
_
:=
context
.
WithTimeout
(
ctx
,
providerRequestTimeout
)
providers
:=
bs
.
routing
.
FindProvidersAsync
(
child
,
k
,
maxProvidersPerRequest
)
for
prov
:=
range
providers
{
provcollect
<-
prov
if
ps
.
AddIfSmallerThan
(
prov
,
-
1
)
{
//Do once per peer
bs
.
send
(
ctx
,
prov
,
message
)
}
}
wg
.
Done
()
}(
e
.
Value
)
}
// When all workers finish, close the providers channel
go
func
()
{
wg
.
Wait
()
close
(
provcollect
)
}()
// Filter out duplicates,
// no need to send our wantlists out twice in a given time period
for
{
select
{
case
p
,
ok
:=
<-
provcollect
:
if
!
ok
{
break
}
provset
[
p
.
Key
()]
=
p
case
<-
ctx
.
Done
()
:
log
.
Error
(
"Context cancelled before we got all the providers!"
)
return
}
}
message
:=
bsmsg
.
New
()
message
.
SetFull
(
true
)
for
_
,
e
:=
range
bs
.
wantlist
.
Entries
()
{
message
.
AddEntry
(
e
.
Value
,
e
.
Priority
,
false
)
}
for
_
,
prov
:=
range
provset
{
bs
.
send
(
ctx
,
prov
,
message
)
}
wg
.
Wait
()
}
func
(
bs
*
bitswap
)
roundWorker
(
ctx
context
.
Context
)
{
...
...
routing/dht/routing.go
浏览文件 @
cfbe92bc
...
...
@@ -11,6 +11,7 @@ import (
pb
"github.com/jbenet/go-ipfs/routing/dht/pb"
kb
"github.com/jbenet/go-ipfs/routing/kbucket"
u
"github.com/jbenet/go-ipfs/util"
pset
"github.com/jbenet/go-ipfs/util/peerset"
)
// asyncQueryBuffer is the size of buffered channels in async queries. This
...
...
@@ -140,7 +141,7 @@ func (dht *IpfsDHT) FindProvidersAsync(ctx context.Context, key u.Key, count int
func
(
dht
*
IpfsDHT
)
findProvidersAsyncRoutine
(
ctx
context
.
Context
,
key
u
.
Key
,
count
int
,
peerOut
chan
peer
.
Peer
)
{
defer
close
(
peerOut
)
ps
:=
n
ewPeerSet
()
ps
:=
pset
.
N
ewPeerSet
()
provs
:=
dht
.
providers
.
GetProviders
(
ctx
,
key
)
for
_
,
p
:=
range
provs
{
// NOTE: assuming that this list of peers is unique
...
...
@@ -207,7 +208,7 @@ func (dht *IpfsDHT) findProvidersAsyncRoutine(ctx context.Context, key u.Key, co
}
}
func
(
dht
*
IpfsDHT
)
addPeerListAsync
(
ctx
context
.
Context
,
k
u
.
Key
,
peers
[]
*
pb
.
Message_Peer
,
ps
*
peerSet
,
count
int
,
out
chan
peer
.
Peer
)
{
func
(
dht
*
IpfsDHT
)
addPeerListAsync
(
ctx
context
.
Context
,
k
u
.
Key
,
peers
[]
*
pb
.
Message_Peer
,
ps
*
p
set
.
P
eerSet
,
count
int
,
out
chan
peer
.
Peer
)
{
var
wg
sync
.
WaitGroup
for
_
,
pbp
:=
range
peers
{
wg
.
Add
(
1
)
...
...
routing/dht/util.go
浏览文件 @
cfbe92bc
...
...
@@ -2,8 +2,6 @@ package dht
import
(
"sync"
peer
"github.com/jbenet/go-ipfs/peer"
)
// Pool size is the number of nodes used for group find/set RPC calls
...
...
@@ -39,45 +37,3 @@ func (c *counter) Size() (s int) {
c
.
mut
.
Unlock
()
return
}
// peerSet is a threadsafe set of peers
type
peerSet
struct
{
ps
map
[
string
]
bool
lk
sync
.
RWMutex
}
func
newPeerSet
()
*
peerSet
{
ps
:=
new
(
peerSet
)
ps
.
ps
=
make
(
map
[
string
]
bool
)
return
ps
}
func
(
ps
*
peerSet
)
Add
(
p
peer
.
Peer
)
{
ps
.
lk
.
Lock
()
ps
.
ps
[
string
(
p
.
ID
())]
=
true
ps
.
lk
.
Unlock
()
}
func
(
ps
*
peerSet
)
Contains
(
p
peer
.
Peer
)
bool
{
ps
.
lk
.
RLock
()
_
,
ok
:=
ps
.
ps
[
string
(
p
.
ID
())]
ps
.
lk
.
RUnlock
()
return
ok
}
func
(
ps
*
peerSet
)
Size
()
int
{
ps
.
lk
.
RLock
()
defer
ps
.
lk
.
RUnlock
()
return
len
(
ps
.
ps
)
}
func
(
ps
*
peerSet
)
AddIfSmallerThan
(
p
peer
.
Peer
,
maxsize
int
)
bool
{
var
success
bool
ps
.
lk
.
Lock
()
if
_
,
ok
:=
ps
.
ps
[
string
(
p
.
ID
())];
!
ok
&&
len
(
ps
.
ps
)
<
maxsize
{
success
=
true
ps
.
ps
[
string
(
p
.
ID
())]
=
true
}
ps
.
lk
.
Unlock
()
return
success
}
util/peerset/peerset.go
0 → 100644
浏览文件 @
cfbe92bc
package
peerset
import
(
peer
"github.com/jbenet/go-ipfs/peer"
"sync"
)
// PeerSet is a threadsafe set of peers
type
PeerSet
struct
{
ps
map
[
string
]
bool
lk
sync
.
RWMutex
}
func
NewPeerSet
()
*
PeerSet
{
ps
:=
new
(
PeerSet
)
ps
.
ps
=
make
(
map
[
string
]
bool
)
return
ps
}
func
(
ps
*
PeerSet
)
Add
(
p
peer
.
Peer
)
{
ps
.
lk
.
Lock
()
ps
.
ps
[
string
(
p
.
ID
())]
=
true
ps
.
lk
.
Unlock
()
}
func
(
ps
*
PeerSet
)
Contains
(
p
peer
.
Peer
)
bool
{
ps
.
lk
.
RLock
()
_
,
ok
:=
ps
.
ps
[
string
(
p
.
ID
())]
ps
.
lk
.
RUnlock
()
return
ok
}
func
(
ps
*
PeerSet
)
Size
()
int
{
ps
.
lk
.
RLock
()
defer
ps
.
lk
.
RUnlock
()
return
len
(
ps
.
ps
)
}
func
(
ps
*
PeerSet
)
AddIfSmallerThan
(
p
peer
.
Peer
,
maxsize
int
)
bool
{
var
success
bool
ps
.
lk
.
Lock
()
if
_
,
ok
:=
ps
.
ps
[
string
(
p
.
ID
())];
!
ok
&&
len
(
ps
.
ps
)
<
maxsize
{
success
=
true
ps
.
ps
[
string
(
p
.
ID
())]
=
true
}
ps
.
lk
.
Unlock
()
return
success
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论