Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
56b316bf
C
ClickHouse
项目概览
2dot5
/
ClickHouse
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
ClickHouse
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
56b316bf
编写于
2月 19, 2016
作者:
A
Alexey Milovidov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixed error when symlinked part couldn't be removed [#METR-20080].
上级
9e81f3ee
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
43 addition
and
12 deletion
+43
-12
dbms/src/Storages/MergeTree/MergeTreeDataPart.cpp
dbms/src/Storages/MergeTree/MergeTreeDataPart.cpp
+2
-2
dbms/src/Storages/tests/CMakeLists.txt
dbms/src/Storages/tests/CMakeLists.txt
+11
-10
dbms/src/Storages/tests/remove_symlink_directory.cpp
dbms/src/Storages/tests/remove_symlink_directory.cpp
+30
-0
未找到文件。
dbms/src/Storages/MergeTree/MergeTreeDataPart.cpp
浏览文件 @
56b316bf
...
...
@@ -350,8 +350,8 @@ size_t MergeTreeDataPart::calcTotalSize(const String & from)
void
MergeTreeDataPart
::
remove
()
const
{
String
from
=
storage
.
full_path
+
name
+
"/"
;
String
to
=
storage
.
full_path
+
"tmp2_"
+
name
+
"/"
;
String
from
=
storage
.
full_path
+
name
;
String
to
=
storage
.
full_path
+
"tmp2_"
+
name
;
Poco
::
File
from_dir
{
from
};
Poco
::
File
to_dir
{
to
};
...
...
dbms/src/Storages/tests/CMakeLists.txt
浏览文件 @
56b316bf
include_directories
(
${
CMAKE_CURRENT_BINARY_DIR
}
)
set
(
SRCS
)
add_executable
(
system_numbers system_numbers.cpp
${
SRCS
}
)
add_executable
(
system_numbers system_numbers.cpp
)
target_link_libraries
(
system_numbers dbms
)
add_executable
(
storage_log storage_log.cpp
${
SRCS
}
)
add_executable
(
storage_log storage_log.cpp
)
target_link_libraries
(
storage_log dbms
)
add_executable
(
hit_log hit_log.cpp
${
SRCS
}
)
add_executable
(
hit_log hit_log.cpp
)
target_link_libraries
(
hit_log dbms
)
add_executable
(
merge_tree merge_tree.cpp
${
SRCS
}
)
add_executable
(
merge_tree merge_tree.cpp
)
target_link_libraries
(
merge_tree dbms
)
add_executable
(
seek_speed_test seek_speed_test.cpp
${
SRCS
}
)
add_executable
(
seek_speed_test seek_speed_test.cpp
)
target_link_libraries
(
seek_speed_test dbms
)
add_executable
(
pk_condition pk_condition.cpp
${
SRCS
}
)
add_executable
(
pk_condition pk_condition.cpp
)
target_link_libraries
(
pk_condition dbms
)
add_check
(
pk_condition
)
add_executable
(
part_checker part_checker.cpp
${
SRCS
}
)
add_executable
(
part_checker part_checker.cpp
)
target_link_libraries
(
part_checker dbms
)
add_executable
(
part_name part_name.cpp
${
SRCS
}
)
add_executable
(
part_name part_name.cpp
)
target_link_libraries
(
part_name dbms
)
add_executable
(
remove_symlink_directory remove_symlink_directory.cpp
)
target_link_libraries
(
remove_symlink_directory dbms
)
dbms/src/Storages/tests/remove_symlink_directory.cpp
0 → 100644
浏览文件 @
56b316bf
#include <unistd.h>
#include <iostream>
#include <Poco/File.h>
#include <Poco/Path.h>
#include <DB/Common/Exception.h>
int
main
(
int
argc
,
char
**
argv
)
try
{
Poco
::
File
dir
(
"./test_dir/"
);
dir
.
createDirectories
();
Poco
::
File
(
"./test_dir/file"
).
createFile
();
if
(
0
!=
symlink
(
"./test_dir"
,
"./test_link"
))
DB
::
throwFromErrno
(
"Cannot create symlink"
);
Poco
::
File
link
(
"./test_link"
);
link
.
renameTo
(
"./test_link2"
);
Poco
::
File
(
"./test_link2"
).
remove
(
true
);
return
0
;
}
catch
(...)
{
std
::
cerr
<<
DB
::
getCurrentExceptionMessage
(
false
)
<<
"
\n
"
;
return
1
;
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录