Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
2c2bcb8a
提交
2c2bcb8a
authored
3月 12, 2015
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #909 from kkoroviev/fix-daemon-races
Dirty hack to fix race conditions in the daemon
上级
796db710
01db359c
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
22 行增加
和
1 行删除
+22
-1
daemon.go
cmd/ipfs/daemon.go
+4
-0
main.go
cmd/ipfs/main.go
+16
-0
request.go
commands/request.go
+2
-1
没有找到文件。
cmd/ipfs/daemon.go
浏览文件 @
2c2bcb8a
...
@@ -267,6 +267,10 @@ func daemonFunc(req cmds.Request, res cmds.Response) {
...
@@ -267,6 +267,10 @@ func daemonFunc(req cmds.Request, res cmds.Response) {
gateway
.
ServeOption
(),
gateway
.
ServeOption
(),
corehttp
.
VersionOption
(),
corehttp
.
VersionOption
(),
}
}
// our global interrupt handler can now try to stop the daemon
close
(
req
.
Context
()
.
InitDone
)
if
rootRedirect
!=
nil
{
if
rootRedirect
!=
nil
{
opts
=
append
(
opts
,
rootRedirect
)
opts
=
append
(
opts
,
rootRedirect
)
}
}
...
...
cmd/ipfs/main.go
浏览文件 @
2c2bcb8a
...
@@ -132,6 +132,14 @@ func main() {
...
@@ -132,6 +132,14 @@ func main() {
os
.
Exit
(
1
)
os
.
Exit
(
1
)
}
}
// our global interrupt handler may try to stop the daemon
// before the daemon is ready to be stopped; this dirty
// workaround is for the daemon only; other commands are always
// ready to be stopped
if
invoc
.
cmd
!=
daemonCmd
{
close
(
invoc
.
req
.
Context
()
.
InitDone
)
}
// ok, finally, run the command invocation.
// ok, finally, run the command invocation.
output
,
err
:=
invoc
.
Run
(
ctx
)
output
,
err
:=
invoc
.
Run
(
ctx
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -479,6 +487,14 @@ func (i *cmdInvocation) setupInterruptHandler() {
...
@@ -479,6 +487,14 @@ func (i *cmdInvocation) setupInterruptHandler() {
for
count
:=
0
;
;
count
++
{
for
count
:=
0
;
;
count
++
{
<-
sig
<-
sig
// if we're still initializing, cannot use `ctx.GetNode()`
select
{
default
:
// initialization not done
fmt
.
Println
(
"Received interrupt signal, shutting down..."
)
os
.
Exit
(
-
1
)
case
<-
ctx
.
InitDone
:
}
// TODO cancel the command context instead
// TODO cancel the command context instead
n
,
err
:=
ctx
.
GetNode
()
n
,
err
:=
ctx
.
GetNode
()
...
...
commands/request.go
浏览文件 @
2c2bcb8a
...
@@ -30,6 +30,7 @@ type Context struct {
...
@@ -30,6 +30,7 @@ type Context struct {
node
*
core
.
IpfsNode
node
*
core
.
IpfsNode
ConstructNode
func
()
(
*
core
.
IpfsNode
,
error
)
ConstructNode
func
()
(
*
core
.
IpfsNode
,
error
)
InitDone
chan
bool
}
}
// GetConfig returns the config of the current Command exection
// GetConfig returns the config of the current Command exection
...
@@ -287,7 +288,7 @@ func NewRequest(path []string, opts OptMap, args []string, file files.File, cmd
...
@@ -287,7 +288,7 @@ func NewRequest(path []string, opts OptMap, args []string, file files.File, cmd
optDefs
=
make
(
map
[
string
]
Option
)
optDefs
=
make
(
map
[
string
]
Option
)
}
}
ctx
:=
Context
{
Context
:
context
.
TODO
()}
ctx
:=
Context
{
Context
:
context
.
TODO
()
,
InitDone
:
make
(
chan
bool
)
}
values
:=
make
(
map
[
string
]
interface
{})
values
:=
make
(
map
[
string
]
interface
{})
req
:=
&
request
{
path
,
opts
,
args
,
file
,
cmd
,
ctx
,
optDefs
,
values
,
os
.
Stdin
}
req
:=
&
request
{
path
,
opts
,
args
,
file
,
cmd
,
ctx
,
optDefs
,
values
,
os
.
Stdin
}
err
:=
req
.
ConvertOptions
()
err
:=
req
.
ConvertOptions
()
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论