Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
indiff7643
Terarkdb
提交
5916efaa
T
Terarkdb
项目概览
indiff7643
/
Terarkdb
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Terarkdb
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
5916efaa
编写于
9月 06, 2019
作者:
Z
ZhaoMing
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix bugs ...
上级
186b3e23
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
15 addition
and
14 deletion
+15
-14
db/compaction_job.cc
db/compaction_job.cc
+2
-1
db/version_builder.cc
db/version_builder.cc
+11
-11
db/version_set.cc
db/version_set.cc
+2
-2
未找到文件。
db/compaction_job.cc
浏览文件 @
5916efaa
...
...
@@ -1632,7 +1632,8 @@ void CompactionJob::ProcessGarbageCollection(SubcompactionState* sub_compact) {
inheritance_chain
.
end
()),
inheritance_chain
.
end
());
Status
s
=
FinishCompactionOutputFile
(
status
,
sub_compact
,
nullptr
,
nullptr
,
{},
inheritance_chain
);
nullptr
,
std
::
unordered_set
<
uint64_t
>
(),
inheritance_chain
);
if
(
status
.
ok
())
{
status
=
s
;
}
...
...
db/version_builder.cc
浏览文件 @
5916efaa
...
...
@@ -87,8 +87,8 @@ class VersionBuilder::Rep {
std
::
unordered_map
<
uint64_t
,
FileMetaData
*>
added_files
;
};
struct
DependenceItem
{
size_t
is_dependence
;
size_t
is_skip_gc
;
size_t
dependence_version
;
size_t
skip_gc_version
;
int
level
;
FileMetaData
*
f
;
};
...
...
@@ -245,9 +245,9 @@ class VersionBuilder::Rep {
continue
;
}
auto
&
item
=
find
->
second
;
item
.
is_dependence
=
dependence_version_
;
item
.
dependence_version
=
dependence_version_
;
if
(
recursive
)
{
item
.
is_skip_gc
=
dependence_version_
;
item
.
skip_gc_version
=
dependence_version_
;
SetDependence
(
item
.
f
,
item
.
f
->
prop
.
purpose
==
kMapSst
,
check_error
);
}
}
...
...
@@ -261,9 +261,9 @@ class VersionBuilder::Rep {
}
assert
(
dependence_map_
.
count
(
file_number
)
>
0
);
auto
&
item
=
dependence_map_
[
file_number
];
item
.
is_skip_gc
=
dependence_version_
;
item
.
skip_gc_version
=
dependence_version_
;
if
(
item
.
level
<
0
)
{
item
.
is_dependence
=
dependence_version_
;
item
.
dependence_version
=
dependence_version_
;
}
if
(
item
.
f
->
prop
.
purpose
==
kMapSst
)
{
SetDependence
(
item
.
f
,
true
,
check_error
);
...
...
@@ -273,7 +273,7 @@ class VersionBuilder::Rep {
}
for
(
auto
it
=
dependence_map_
.
begin
();
it
!=
dependence_map_
.
end
();
)
{
auto
&
item
=
it
->
second
;
if
(
item
.
is_dependence
==
dependence_version_
||
item
.
level
>=
0
)
{
if
(
item
.
dependence_version
==
dependence_version_
||
item
.
level
>=
0
)
{
assert
(
inheritance_counter_
.
count
(
item
.
f
->
fd
.
GetNumber
())
==
0
);
++
it
;
}
else
{
...
...
@@ -563,7 +563,7 @@ class VersionBuilder::Rep {
}
for
(
auto
&
pair
:
dependence_map_
)
{
auto
&
item
=
pair
.
second
;
if
(
item
.
is_dependence
==
dependence_version_
&&
item
.
level
==
-
1
)
{
if
(
item
.
dependence_version
==
dependence_version_
&&
item
.
level
==
-
1
)
{
auto
find
=
delta_antiquation_
.
find
(
pair
.
first
);
if
(
find
!=
delta_antiquation_
.
end
())
{
item
.
f
->
num_antiquation
+=
find
->
second
;
...
...
@@ -577,8 +577,8 @@ class VersionBuilder::Rep {
return
false
;
}
auto
&
item
=
find
->
second
;
file_metadata
->
is_skip_gc
|=
item
.
is_skip_gc
;
return
item
.
is_dependence
==
dependence_version_
;
file_metadata
->
is_skip_gc
|=
item
.
skip_gc_version
==
dependence_version_
;
return
item
.
dependence_version
==
dependence_version_
;
};
vstorage
->
ShrinkDependenceMap
(
&
exists
,
c_style_callback
(
exists
));
vstorage
->
set_read_amplification
(
read_amp
);
...
...
@@ -601,7 +601,7 @@ class VersionBuilder::Rep {
}
for
(
auto
&
pair
:
dependence_map_
)
{
auto
&
item
=
pair
.
second
;
if
(
item
.
is_dependence
==
dependence_version_
&&
item
.
level
==
-
1
)
{
if
(
item
.
dependence_version
==
dependence_version_
&&
item
.
level
==
-
1
)
{
files_meta
.
emplace_back
(
item
.
f
,
-
1
);
}
}
...
...
db/version_set.cc
浏览文件 @
5916efaa
...
...
@@ -1206,7 +1206,7 @@ Status Version::inplace_decode(LazySlice* slice, LazySliceRep* rep) const {
Slice
user_key
(
reinterpret_cast
<
const
char
*>
(
rep
->
data
[
0
]),
rep
->
data
[
1
]);
uint64_t
sequence
=
rep
->
data
[
2
];
uint64_t
file_number
=
slice
->
file_number
();
auto
dependence_map
=
storage_info_
.
dependence_map
();
auto
&
dependence_map
=
storage_info_
.
dependence_map
();
assert
(
dependence_map
.
count
(
file_number
)
>
0
);
const
FileMetaData
*
file_metadata
=
dependence_map
.
find
(
file_number
)
->
second
;
bool
value_found
=
false
;
...
...
@@ -1240,7 +1240,7 @@ void Version::TransToCombined(const Slice& user_key, uint64_t sequence,
return
;
}
uint64_t
file_number
=
SeparateHelper
::
DecodeFileNumber
(
value
);
auto
dependence_map
=
storage_info_
.
dependence_map
();
auto
&
dependence_map
=
storage_info_
.
dependence_map
();
auto
find
=
dependence_map
.
find
(
file_number
);
if
(
find
==
dependence_map
.
end
())
{
value
.
reset
(
Status
::
Corruption
(
"Separate value dependence missing"
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录