Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
96a86cac
提交
96a86cac
authored
4月 28, 2015
作者:
Tommi Virtanen
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Record Datastore metrics for flatfs and leveldb
上级
2dd9b168
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
30 行增加
和
3 行删除
+30
-3
fsrepo.go
repo/fsrepo/fsrepo.go
+30
-3
没有找到文件。
repo/fsrepo/fsrepo.go
浏览文件 @
96a86cac
...
...
@@ -13,6 +13,7 @@ import (
ds
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore"
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore/flatfs"
levelds
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore/leveldb"
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore/measure"
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore/mount"
ldbopts
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/github.com/syndtr/goleveldb/leveldb/opt"
repo
"github.com/ipfs/go-ipfs/repo"
...
...
@@ -93,7 +94,9 @@ type FSRepo struct {
config
*
config
.
Config
ds
ds
.
ThreadSafeDatastore
// tracked separately for use in Close; do not use directly.
leveldbDS
levelds
.
Datastore
leveldbDS
levelds
.
Datastore
metricsBlocks
measure
.
DatastoreCloser
metricsLevelDB
measure
.
DatastoreCloser
}
var
_
repo
.
Repo
=
(
*
FSRepo
)(
nil
)
...
...
@@ -329,9 +332,27 @@ func (r *FSRepo) openDatastore() error {
return
errors
.
New
(
"unable to open flatfs datastore"
)
}
// Add our PeerID to metrics paths to keep them unique
//
// As some tests just pass a zero-value Config to fsrepo.Init,
// cope with missing PeerID.
id
:=
r
.
config
.
Identity
.
PeerID
if
id
==
""
{
// the tests pass in a zero Config; cope with it
id
=
fmt
.
Sprintf
(
"uninitialized_%p"
,
r
)
}
prefix
:=
"fsrepo."
+
id
+
".datastore."
r
.
metricsBlocks
=
measure
.
New
(
prefix
+
"blocks"
,
blocksDS
)
r
.
metricsLevelDB
=
measure
.
New
(
prefix
+
"leveldb"
,
r
.
leveldbDS
)
mountDS
:=
mount
.
New
([]
mount
.
Mount
{
{
Prefix
:
ds
.
NewKey
(
"/blocks"
),
Datastore
:
blocksDS
},
{
Prefix
:
ds
.
NewKey
(
"/"
),
Datastore
:
r
.
leveldbDS
},
{
Prefix
:
ds
.
NewKey
(
"/blocks"
),
Datastore
:
r
.
metricsBlocks
,
},
{
Prefix
:
ds
.
NewKey
(
"/"
),
Datastore
:
r
.
metricsLevelDB
,
},
})
// Make sure it's ok to claim the virtual datastore from mount as
// threadsafe. There's no clean way to make mount itself provide
...
...
@@ -365,6 +386,12 @@ func (r *FSRepo) Close() error {
return
errors
.
New
(
"repo is closed"
)
}
if
err
:=
r
.
metricsBlocks
.
Close
();
err
!=
nil
{
return
err
}
if
err
:=
r
.
metricsLevelDB
.
Close
();
err
!=
nil
{
return
err
}
if
err
:=
r
.
leveldbDS
.
Close
();
err
!=
nil
{
return
err
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论