Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
0d0b4fc8
提交
0d0b4fc8
authored
9月 27, 2019
作者:
Steven Allen
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(systemd): extract socket activation logic
上级
37c19cc6
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
4 行增加
和
72 行删除
+4
-72
daemon.go
cmd/ipfs/daemon.go
+3
-3
sockets.go
cmd/ipfs/sockets/sockets.go
+0
-12
sockets_linux.go
cmd/ipfs/sockets/sockets_linux.go
+0
-57
go.mod
go.mod
+1
-0
go.sum
go.sum
+0
-0
没有找到文件。
cmd/ipfs/daemon.go
浏览文件 @
0d0b4fc8
...
...
@@ -15,7 +15,6 @@ import (
version
"github.com/ipfs/go-ipfs"
config
"github.com/ipfs/go-ipfs-config"
cserial
"github.com/ipfs/go-ipfs-config/serialize"
sockets
"github.com/ipfs/go-ipfs/cmd/ipfs/sockets"
utilmain
"github.com/ipfs/go-ipfs/cmd/ipfs/util"
oldcmds
"github.com/ipfs/go-ipfs/commands"
"github.com/ipfs/go-ipfs/core"
...
...
@@ -27,6 +26,7 @@ import (
nodeMount
"github.com/ipfs/go-ipfs/fuse/node"
fsrepo
"github.com/ipfs/go-ipfs/repo/fsrepo"
migrate
"github.com/ipfs/go-ipfs/repo/fsrepo/migrations"
sockets
"github.com/libp2p/go-socket-activation"
"github.com/hashicorp/go-multierror"
cmds
"github.com/ipfs/go-ipfs-cmds"
...
...
@@ -440,7 +440,7 @@ func serveHTTPApi(req *cmds.Request, cctx *oldcmds.Context) (<-chan error, error
return
nil
,
fmt
.
Errorf
(
"serveHTTPApi: GetConfig() failed: %s"
,
err
)
}
listeners
,
err
:=
sockets
.
Take
Socket
s
(
"io.ipfs.api"
)
listeners
,
err
:=
sockets
.
Take
Listener
s
(
"io.ipfs.api"
)
if
err
!=
nil
{
return
nil
,
fmt
.
Errorf
(
"serveHTTPApi: socket activation failed: %s"
,
err
)
}
...
...
@@ -580,7 +580,7 @@ func serveHTTPGateway(req *cmds.Request, cctx *oldcmds.Context) (<-chan error, e
writable
=
cfg
.
Gateway
.
Writable
}
listeners
,
err
:=
sockets
.
Take
Socket
s
(
"io.ipfs.gateway"
)
listeners
,
err
:=
sockets
.
Take
Listener
s
(
"io.ipfs.gateway"
)
if
err
!=
nil
{
return
nil
,
fmt
.
Errorf
(
"serveHTTPGateway: socket activation failed: %s"
,
err
)
}
...
...
cmd/ipfs/sockets/sockets.go
deleted
100644 → 0
浏览文件 @
37c19cc6
// +build !linux
package
sockets
import
(
manet
"github.com/multiformats/go-multiaddr-net"
)
// TakeSockets takes the sockets associated with the given name.
func
TakeSockets
(
name
string
)
([]
manet
.
Listener
,
error
)
{
return
nil
,
nil
}
cmd/ipfs/sockets/sockets_linux.go
deleted
100644 → 0
浏览文件 @
37c19cc6
// +build linux
package
sockets
import
(
"sync"
activation
"github.com/coreos/go-systemd/activation"
logging
"github.com/ipfs/go-log"
manet
"github.com/multiformats/go-multiaddr-net"
)
var
log
=
logging
.
Logger
(
"socket-activation"
)
var
(
socketsMu
sync
.
Mutex
sockets
map
[
string
][]
manet
.
Listener
)
func
initSockets
()
{
if
sockets
!=
nil
{
return
}
nlisteners
,
err
:=
activation
.
ListenersWithNames
()
// Do this before checking the error. We need this to be non-nil so we
// don't try again.
sockets
=
make
(
map
[
string
][]
manet
.
Listener
,
len
(
nlisteners
))
if
err
!=
nil
{
log
.
Errorf
(
"error parsing systemd sockets: %s"
,
err
)
return
}
for
name
,
nls
:=
range
nlisteners
{
mls
:=
make
([]
manet
.
Listener
,
0
,
len
(
nls
))
for
_
,
nl
:=
range
nls
{
ml
,
err
:=
manet
.
WrapNetListener
(
nl
)
if
err
!=
nil
{
log
.
Errorf
(
"error converting a systemd-socket to a multiaddr listener: %s"
,
err
)
nl
.
Close
()
continue
}
mls
=
append
(
mls
,
ml
)
}
sockets
[
name
]
=
mls
}
}
// TakeSockets takes the sockets associated with the given name.
func
TakeSockets
(
name
string
)
([]
manet
.
Listener
,
error
)
{
socketsMu
.
Lock
()
defer
socketsMu
.
Unlock
()
initSockets
()
s
:=
sockets
[
name
]
delete
(
sockets
,
name
)
return
s
,
nil
}
go.mod
浏览文件 @
0d0b4fc8
...
...
@@ -79,6 +79,7 @@ require (
github.com/libp2p/go-libp2p-tls v0.1.1
github.com/libp2p/go-libp2p-yamux v0.2.1
github.com/libp2p/go-maddr-filter v0.0.5
github.com/libp2p/go-socket-activation v0.0.1
github.com/mattn/go-runewidth v0.0.4 // indirect
github.com/mitchellh/go-homedir v1.1.0
github.com/mr-tron/base58 v1.1.2
...
...
go.sum
浏览文件 @
0d0b4fc8
差异被折叠。
点击展开。
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论