Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
efa442ad
提交
efa442ad
authored
5月 25, 2015
作者:
Jeromy
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
adjust naming
上级
f574cd4b
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
8 行增加
和
10 行删除
+8
-10
bitswap.go
exchange/bitswap/bitswap.go
+4
-6
workers.go
exchange/bitswap/workers.go
+4
-4
没有找到文件。
exchange/bitswap/bitswap.go
浏览文件 @
efa442ad
...
@@ -82,7 +82,7 @@ func New(parent context.Context, p peer.ID, network bsnet.BitSwapNetwork,
...
@@ -82,7 +82,7 @@ func New(parent context.Context, p peer.ID, network bsnet.BitSwapNetwork,
notifications
:
notif
,
notifications
:
notif
,
engine
:
decision
.
NewEngine
(
ctx
,
bstore
),
// TODO close the engine with Close() method
engine
:
decision
.
NewEngine
(
ctx
,
bstore
),
// TODO close the engine with Close() method
network
:
network
,
network
:
network
,
batchRequests
:
make
(
chan
*
blockRequest
,
sizeBatchRequestChan
),
findKeys
:
make
(
chan
*
blockRequest
,
sizeBatchRequestChan
),
process
:
px
,
process
:
px
,
newBlocks
:
make
(
chan
*
blocks
.
Block
,
HasBlockBufferSize
),
newBlocks
:
make
(
chan
*
blocks
.
Block
,
HasBlockBufferSize
),
provideKeys
:
make
(
chan
u
.
Key
),
provideKeys
:
make
(
chan
u
.
Key
),
...
@@ -115,10 +115,8 @@ type Bitswap struct {
...
@@ -115,10 +115,8 @@ type Bitswap struct {
notifications
notifications
.
PubSub
notifications
notifications
.
PubSub
// Requests for a set of related blocks
// send keys to a worker to find and connect to providers for them
// the assumption is made that the same peer is likely to
findKeys
chan
*
blockRequest
// have more than a single block in the set
batchRequests
chan
*
blockRequest
engine
*
decision
.
Engine
engine
*
decision
.
Engine
...
@@ -209,7 +207,7 @@ func (bs *Bitswap) GetBlocks(ctx context.Context, keys []u.Key) (<-chan *blocks.
...
@@ -209,7 +207,7 @@ func (bs *Bitswap) GetBlocks(ctx context.Context, keys []u.Key) (<-chan *blocks.
ctx
:
ctx
,
ctx
:
ctx
,
}
}
select
{
select
{
case
bs
.
batchRequest
s
<-
req
:
case
bs
.
findKey
s
<-
req
:
return
promise
,
nil
return
promise
,
nil
case
<-
ctx
.
Done
()
:
case
<-
ctx
.
Done
()
:
return
nil
,
ctx
.
Err
()
return
nil
,
ctx
.
Err
()
...
...
exchange/bitswap/workers.go
浏览文件 @
efa442ad
...
@@ -31,7 +31,7 @@ func init() {
...
@@ -31,7 +31,7 @@ func init() {
func
(
bs
*
Bitswap
)
startWorkers
(
px
process
.
Process
,
ctx
context
.
Context
)
{
func
(
bs
*
Bitswap
)
startWorkers
(
px
process
.
Process
,
ctx
context
.
Context
)
{
// Start up a worker to handle block requests this node is making
// Start up a worker to handle block requests this node is making
px
.
Go
(
func
(
px
process
.
Process
)
{
px
.
Go
(
func
(
px
process
.
Process
)
{
bs
.
clientWorke
r
(
ctx
)
bs
.
providerConnecto
r
(
ctx
)
})
})
// Start up workers to handle requests from other nodes for the data on this node
// Start up workers to handle requests from other nodes for the data on this node
...
@@ -134,13 +134,13 @@ func (bs *Bitswap) provideCollector(ctx context.Context) {
...
@@ -134,13 +134,13 @@ func (bs *Bitswap) provideCollector(ctx context.Context) {
}
}
}
}
//
TODO: figure out clientWorkers purpose in life
//
connects to providers for the given keys
func
(
bs
*
Bitswap
)
clientWorke
r
(
parent
context
.
Context
)
{
func
(
bs
*
Bitswap
)
providerConnecto
r
(
parent
context
.
Context
)
{
defer
log
.
Info
(
"bitswap client worker shutting down..."
)
defer
log
.
Info
(
"bitswap client worker shutting down..."
)
for
{
for
{
select
{
select
{
case
req
:=
<-
bs
.
batchRequest
s
:
case
req
:=
<-
bs
.
findKey
s
:
keys
:=
req
.
keys
keys
:=
req
.
keys
if
len
(
keys
)
==
0
{
if
len
(
keys
)
==
0
{
log
.
Warning
(
"Received batch request for zero blocks"
)
log
.
Warning
(
"Received batch request for zero blocks"
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论