Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
c2877b20
提交
c2877b20
authored
1月 12, 2015
作者:
Brian Tiger Chow
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor(init, repo): init logs in fsrepo
上级
c5da1561
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
23 行增加
和
47 行删除
+23
-47
init.go
cmd/ipfs/init.go
+15
-43
fsrepo.go
repo/fsrepo/fsrepo.go
+8
-0
logs.go
repo/logs.go
+0
-4
没有找到文件。
cmd/ipfs/init.go
浏览文件 @
c2877b20
...
...
@@ -4,9 +4,7 @@ import (
"bytes"
"encoding/base64"
"fmt"
"os"
"path"
"path/filepath"
context
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/go.net/context"
cmds
"github.com/jbenet/go-ipfs/commands"
...
...
@@ -18,7 +16,7 @@ import (
peer
"github.com/jbenet/go-ipfs/p2p/peer"
repo
"github.com/jbenet/go-ipfs/repo"
config
"github.com/jbenet/go-ipfs/repo/config"
"github.com/jbenet/go-ipfs/repo/fsrepo"
fsrepo
"github.com/jbenet/go-ipfs/repo/fsrepo"
u
"github.com/jbenet/go-ipfs/util"
debugerror
"github.com/jbenet/go-ipfs/util/debugerror"
)
...
...
@@ -98,17 +96,19 @@ func doInit(configRoot string, force bool, nBitsForKeypair int) (interface{}, er
return
nil
,
err
}
r
epo
:=
fsrepo
.
At
(
configRoot
)
if
err
:=
r
epo
.
Open
();
err
!=
nil
{
r
:=
fsrepo
.
At
(
configRoot
)
if
err
:=
r
.
Open
();
err
!=
nil
{
return
nil
,
err
}
if
err
:=
r
epo
.
SetConfig
(
conf
);
err
!=
nil
{
if
err
:=
r
.
SetConfig
(
conf
);
err
!=
nil
{
return
nil
,
err
}
if
err
:=
repo
.
Close
();
err
!=
nil
{
if
err
:=
r
.
Close
();
err
!=
nil
{
return
nil
,
err
}
if
err
:=
repo
.
ConfigureEventLogger
(
conf
.
Logs
);
err
!=
nil
{
return
nil
,
err
}
err
=
addTheWelcomeFile
(
conf
)
if
err
!=
nil
{
return
nil
,
err
...
...
@@ -167,7 +167,7 @@ func initConfig(nBitsForKeypair int) (*config.Config, error) {
return
nil
,
err
}
logConfig
,
err
:=
initLogs
(
""
)
// TODO allow user to override dir
logConfig
,
err
:=
initLogs
(
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -191,7 +191,7 @@ func initConfig(nBitsForKeypair int) (*config.Config, error) {
Bootstrap
:
bootstrapPeers
,
Datastore
:
*
ds
,
Logs
:
logConfig
,
Logs
:
*
logConfig
,
Identity
:
identity
,
// setup the node mount points.
...
...
@@ -240,42 +240,14 @@ func identityConfig(nbits int) (config.Identity, error) {
return
ident
,
nil
}
// initLogs initializes the event logger at the specified path. It uses the
// default log path if no path is provided.
func
initLogs
(
logpath
string
)
(
config
.
Logs
,
error
)
{
if
len
(
logpath
)
==
0
{
var
err
error
logpath
,
err
=
config
.
LogsPath
(
""
)
if
err
!=
nil
{
return
config
.
Logs
{},
debugerror
.
Wrap
(
err
)
}
}
err
:=
initCheckDir
(
logpath
)
// initLogs initializes the event logger.
func
initLogs
()
(
*
config
.
Logs
,
error
)
{
logpath
,
err
:=
config
.
LogsPath
(
""
)
if
err
!=
nil
{
return
config
.
Logs
{},
debugerror
.
Errorf
(
"logs: %s"
,
err
)
return
nil
,
err
}
conf
:=
config
.
Logs
{
Filename
:
path
.
Join
(
logpath
,
"events.log"
),
}
err
=
repo
.
ConfigureEventLogger
(
conf
)
if
err
!=
nil
{
return
conf
,
err
}
return
conf
,
nil
}
// initCheckDir ensures the directory exists and is writable
func
initCheckDir
(
path
string
)
error
{
// Construct the path if missing
if
err
:=
os
.
MkdirAll
(
path
,
os
.
ModePerm
);
err
!=
nil
{
return
err
}
// Check the directory is writeable
if
f
,
err
:=
os
.
Create
(
filepath
.
Join
(
path
,
"._check_writeable"
));
err
==
nil
{
os
.
Remove
(
f
.
Name
())
}
else
{
return
debugerror
.
New
(
"'"
+
path
+
"' is not writeable"
)
}
return
nil
return
&
conf
,
nil
}
repo/fsrepo/fsrepo.go
浏览文件 @
c2877b20
...
...
@@ -38,6 +38,14 @@ func (r *FSRepo) Open() error {
return
debugerror
.
Errorf
(
"datastore: %s"
,
err
)
}
logpath
,
err
:=
config
.
LogsPath
(
""
)
if
err
!=
nil
{
return
debugerror
.
Wrap
(
err
)
}
if
err
:=
initCheckDir
(
logpath
);
err
!=
nil
{
return
debugerror
.
Errorf
(
"logs: %s"
,
err
)
}
return
nil
}
...
...
repo/logs.go
浏览文件 @
c2877b20
...
...
@@ -7,22 +7,18 @@ import (
)
func
ConfigureEventLogger
(
config
config
.
Logs
)
error
{
if
util
.
Debug
{
eventlog
.
Configure
(
eventlog
.
LevelDebug
)
}
else
{
eventlog
.
Configure
(
eventlog
.
LevelInfo
)
}
eventlog
.
Configure
(
eventlog
.
LdJSONFormatter
)
rotateConf
:=
eventlog
.
LogRotatorConfig
{
Filename
:
config
.
Filename
,
MaxSizeMB
:
config
.
MaxSizeMB
,
MaxBackups
:
config
.
MaxBackups
,
MaxAgeDays
:
config
.
MaxAgeDays
,
}
eventlog
.
Configure
(
eventlog
.
OutputRotatingLogFile
(
rotateConf
))
return
nil
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论