Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
cf62f63b
提交
cf62f63b
authored
1月 02, 2015
作者:
Juan Batiz-Benet
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
better daemon + main exit semantics
上级
e21b1f66
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
36 行增加
和
29 行删除
+36
-29
daemon.go
cmd/ipfs/daemon.go
+17
-17
main.go
cmd/ipfs/main.go
+19
-12
没有找到文件。
cmd/ipfs/daemon.go
浏览文件 @
cf62f63b
...
...
@@ -158,27 +158,27 @@ func listenAndServeAPI(node *core.IpfsNode, req cmds.Request, addr ma.Multiaddr)
ifpsHandler
:=
&
ipfsHandler
{
node
}
mux
.
Handle
(
"/ipfs/"
,
ifpsHandler
)
done
:=
make
(
chan
struct
{},
1
)
defer
func
()
{
done
<-
struct
{}{}
}()
// if the server exits beforehand
var
serverError
error
serverExited
:=
make
(
chan
struct
{})
// go wait until the node dies
go
func
()
{
select
{
case
<-
node
.
Closed
()
:
case
<-
done
:
return
}
log
.
Infof
(
"terminating daemon at %s..."
,
addr
)
server
.
Shutdown
<-
true
fmt
.
Printf
(
"daemon listening on %s
\n
"
,
addr
)
serverError
=
server
.
ListenAndServe
(
host
,
mux
)
close
(
serverExited
)
}()
fmt
.
Printf
(
"daemon listening on %s
\n
"
,
addr
)
if
err
:=
server
.
ListenAndServe
(
host
,
mux
);
err
!=
nil
{
return
err
// wait for server to exit.
select
{
case
<-
serverExited
:
// if node being closed before server exits, close server
case
<-
node
.
Closing
()
:
log
.
Infof
(
"daemon at %s terminating..."
,
addr
)
server
.
Shutdown
<-
true
<-
serverExited
// now, DO wait until server exits
}
return
nil
log
.
Infof
(
"daemon at %s terminated"
,
addr
)
return
serverError
}
cmd/ipfs/main.go
浏览文件 @
cf62f63b
...
...
@@ -490,25 +490,32 @@ func (i *cmdInvocation) setupInterruptHandler() {
sig
:=
allInterruptSignals
()
go
func
()
{
// first time, try to shut down.
for
{
// first time, try to shut down.
// loop because we may be
for
count
:=
0
;
;
count
++
{
<-
sig
log
.
Critical
(
"Received interrupt signal, shutting down..."
)
n
,
err
:=
ctx
.
GetNode
()
if
err
==
nil
{
go
n
.
Close
()
select
{
case
<-
n
.
Closed
()
:
case
<-
sig
:
log
.
Critical
(
"Received another interrupt signal, terminating..."
)
}
if
err
!=
nil
{
log
.
Error
(
err
)
log
.
Critical
(
"Received interrupt signal, terminating..."
)
os
.
Exit
(
-
1
)
}
os
.
Exit
(
0
)
switch
count
{
case
0
:
log
.
Critical
(
"Received interrupt signal, shutting down..."
)
go
func
()
{
n
.
Close
()
log
.
Info
(
"Gracefully shut down."
)
}()
default
:
log
.
Critical
(
"Received another interrupt before graceful shutdown, terminating..."
)
os
.
Exit
(
-
1
)
}
}
}()
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论