Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
c5b40b3b
提交
c5b40b3b
authored
6月 11, 2015
作者:
Jeromy
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
prevent wantmanager from leaking goroutines (and memory)
License: MIT Signed-off-by:
Jeromy
<
jeromyj@gmail.com
>
上级
feba3e1d
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
37 行增加
和
24 行删除
+37
-24
wantmanager.go
exchange/bitswap/wantmanager.go
+37
-24
没有找到文件。
exchange/bitswap/wantmanager.go
浏览文件 @
c5b40b3b
...
...
@@ -137,36 +137,49 @@ func (mq *msgQueue) runQueue(ctx context.Context) {
for
{
select
{
case
<-
mq
.
work
:
// there is work to be done
err
:=
mq
.
network
.
ConnectTo
(
ctx
,
mq
.
p
)
if
err
!=
nil
{
log
.
Noticef
(
"cant connect to peer %s: %s"
,
mq
.
p
,
err
)
// TODO: cant connect, what now?
continue
}
// grab outgoing message
mq
.
outlk
.
Lock
()
wlm
:=
mq
.
out
if
wlm
==
nil
||
wlm
.
Empty
()
{
mq
.
outlk
.
Unlock
()
continue
}
mq
.
out
=
nil
mq
.
outlk
.
Unlock
()
// send wantlist updates
err
=
mq
.
network
.
SendMessage
(
ctx
,
mq
.
p
,
wlm
)
if
err
!=
nil
{
log
.
Noticef
(
"bitswap send error: %s"
,
err
)
// TODO: what do we do if this fails?
}
mq
.
doWork
(
ctx
)
case
<-
mq
.
done
:
return
}
}
}
func
(
mq
*
msgQueue
)
doWork
(
ctx
context
.
Context
)
{
// allow a minute for connections
// this includes looking them up in the dht
// dialing them, and handshaking
conctx
,
cancel
:=
context
.
WithTimeout
(
ctx
,
time
.
Minute
)
defer
cancel
()
err
:=
mq
.
network
.
ConnectTo
(
conctx
,
mq
.
p
)
if
err
!=
nil
{
log
.
Noticef
(
"cant connect to peer %s: %s"
,
mq
.
p
,
err
)
// TODO: cant connect, what now?
return
}
// grab outgoing message
mq
.
outlk
.
Lock
()
wlm
:=
mq
.
out
mq
.
out
=
nil
mq
.
outlk
.
Unlock
()
if
wlm
==
nil
||
wlm
.
Empty
()
{
return
}
sendctx
,
cancel
:=
context
.
WithTimeout
(
ctx
,
time
.
Second
*
30
)
defer
cancel
()
// send wantlist updates
err
=
mq
.
network
.
SendMessage
(
sendctx
,
mq
.
p
,
wlm
)
if
err
!=
nil
{
log
.
Noticef
(
"bitswap send error: %s"
,
err
)
// TODO: what do we do if this fails?
return
}
}
func
(
pm
*
WantManager
)
Connected
(
p
peer
.
ID
)
{
pm
.
connect
<-
p
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论