Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
soremi
oceanbase
提交
4891d24b
O
oceanbase
项目概览
soremi
/
oceanbase
与 Fork 源项目一致
Fork自
oceanbase / oceanbase
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oceanbase
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
4891d24b
编写于
9月 02, 2022
作者:
O
obdev
提交者:
LINGuanRen
9月 02, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[CP] Fix ObTmpTenantFileStore may be wild ptr.
上级
612686a5
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
168 addition
and
97 deletion
+168
-97
src/storage/blocksstable/ob_tmp_file_store.cpp
src/storage/blocksstable/ob_tmp_file_store.cpp
+88
-39
src/storage/blocksstable/ob_tmp_file_store.h
src/storage/blocksstable/ob_tmp_file_store.h
+26
-4
unittest/storage/blocksstable/test_tmp_file.cpp
unittest/storage/blocksstable/test_tmp_file.cpp
+54
-54
未找到文件。
src/storage/blocksstable/ob_tmp_file_store.cpp
浏览文件 @
4891d24b
...
...
@@ -715,7 +715,7 @@ int64_t ObTmpTenantMacroBlockManager::get_next_blk_id()
}
ObTmpTenantFileStore
::
ObTmpTenantFileStore
()
:
tmp_block_manager_
(),
page_cache_
(
NULL
),
tmp_mem_block_manager_
(),
file_handle_
(),
allocator_
(),
is_inited_
(
false
)
:
tmp_block_manager_
(),
page_cache_
(
NULL
),
tmp_mem_block_manager_
(),
file_handle_
(),
allocator_
(),
is_inited_
(
false
)
,
ref_cnt_
(
0
)
{}
ObTmpTenantFileStore
::~
ObTmpTenantFileStore
()
...
...
@@ -723,6 +723,25 @@ ObTmpTenantFileStore::~ObTmpTenantFileStore()
destroy
();
}
void
ObTmpTenantFileStore
::
inc_ref
()
{
ATOMIC_INC
(
&
ref_cnt_
);
}
void
ObTmpTenantFileStore
::
dec_ref
()
{
int
ret
=
OB_SUCCESS
;
const
int64_t
tmp_ref
=
ATOMIC_SAF
(
&
ref_cnt_
,
1
);
if
(
tmp_ref
<
0
)
{
ret
=
OB_ERR_UNEXPECTED
;
STORAGE_LOG
(
ERROR
,
"bug: ref_cnt < 0"
,
K
(
ret
),
K
(
tmp_ref
),
K
(
lbt
()));
ob_abort
();
}
else
if
(
0
==
tmp_ref
)
{
this
->~
ObTmpTenantFileStore
();
allocator_
.
free
(
this
);
}
}
int
ObTmpTenantFileStore
::
init
(
const
uint64_t
tenant_id
,
const
ObStorageFileHandle
&
file_handle
)
{
int
ret
=
OB_SUCCESS
;
...
...
@@ -1184,6 +1203,48 @@ int ObTmpTenantFileStore::get_disk_macro_block_list(common::ObIArray<MacroBlockI
return
ret
;
}
ObTmpTenantFileStoreHandle
::
ObTmpTenantFileStoreHandle
()
:
tenant_store_
()
{}
ObTmpTenantFileStoreHandle
::~
ObTmpTenantFileStoreHandle
()
{
reset
();
}
void
ObTmpTenantFileStoreHandle
::
set_tenant_store
(
ObTmpTenantFileStore
*
tenant_store
)
{
if
(
OB_NOT_NULL
(
tenant_store
))
{
reset
();
tenant_store
->
inc_ref
();
// ref for handle
tenant_store_
=
tenant_store
;
}
}
ObTmpTenantFileStoreHandle
&
ObTmpTenantFileStoreHandle
::
operator
=
(
const
ObTmpTenantFileStoreHandle
&
other
)
{
if
(
&
other
!=
this
)
{
set_tenant_store
(
other
.
tenant_store_
);
}
return
*
this
;
}
bool
ObTmpTenantFileStoreHandle
::
is_empty
()
const
{
return
NULL
==
tenant_store_
;
}
bool
ObTmpTenantFileStoreHandle
::
is_valid
()
const
{
return
NULL
!=
tenant_store_
;
}
void
ObTmpTenantFileStoreHandle
::
reset
()
{
if
(
OB_NOT_NULL
(
tenant_store_
))
{
tenant_store_
->
dec_ref
();
// ref for handle
tenant_store_
=
NULL
;
}
}
ObTmpFileStore
&
ObTmpFileStore
::
get_instance
()
{
static
ObTmpFileStore
instance
;
...
...
@@ -1226,10 +1287,10 @@ int ObTmpFileStore::init(const ObStorageFileHandle& file_handle)
int
ObTmpFileStore
::
alloc
(
const
int64_t
dir_id
,
const
uint64_t
tenant_id
,
const
int64_t
size
,
ObTmpFileExtent
&
extent
)
{
int
ret
=
OB_SUCCESS
;
ObTmpTenantFileStore
*
store
=
NULL
;
if
(
OB_FAIL
(
OB_TMP_FILE_STORE
.
get_store
(
tenant_id
,
stor
e
)))
{
ObTmpTenantFileStore
Handle
store_handle
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store_handl
e
)))
{
STORAGE_LOG
(
WARN
,
"fail to get tmp tenant file store"
,
K
(
ret
),
K
(
tenant_id
));
}
else
if
(
OB_FAIL
(
store
->
alloc
(
dir_id
,
tenant_id
,
size
,
extent
)))
{
}
else
if
(
OB_FAIL
(
store
_handle
.
get_tenant_store
()
->
alloc
(
dir_id
,
tenant_id
,
size
,
extent
)))
{
STORAGE_LOG
(
WARN
,
"fail to allocate extents"
,
K
(
ret
),
K
(
tenant_id
),
K
(
dir_id
),
K
(
size
),
K
(
extent
));
}
return
ret
;
...
...
@@ -1238,10 +1299,10 @@ int ObTmpFileStore::alloc(const int64_t dir_id, const uint64_t tenant_id, const
int
ObTmpFileStore
::
read
(
const
uint64_t
tenant_id
,
ObTmpBlockIOInfo
&
io_info
,
ObTmpFileIOHandle
&
handle
)
{
int
ret
=
OB_SUCCESS
;
ObTmpTenantFileStore
*
store
=
NULL
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
)))
{
ObTmpTenantFileStore
Handle
store_handle
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
_handle
)))
{
STORAGE_LOG
(
WARN
,
"fail to get tmp tenant file store"
,
K
(
ret
),
K
(
tenant_id
),
K
(
tenant_id
),
K
(
io_info
),
K
(
handle
));
}
else
if
(
OB_FAIL
(
store
->
read
(
io_info
,
handle
)))
{
}
else
if
(
OB_FAIL
(
store
_handle
.
get_tenant_store
()
->
read
(
io_info
,
handle
)))
{
STORAGE_LOG
(
WARN
,
"fail to read the extent"
,
K
(
ret
),
K
(
tenant_id
),
K
(
io_info
),
K
(
handle
));
}
return
ret
;
...
...
@@ -1250,10 +1311,10 @@ int ObTmpFileStore::read(const uint64_t tenant_id, ObTmpBlockIOInfo& io_info, Ob
int
ObTmpFileStore
::
write
(
const
uint64_t
tenant_id
,
const
ObTmpBlockIOInfo
&
io_info
)
{
int
ret
=
OB_SUCCESS
;
ObTmpTenantFileStore
*
store
=
NULL
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
)))
{
ObTmpTenantFileStore
Handle
store_handle
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
_handle
)))
{
STORAGE_LOG
(
WARN
,
"fail to get tmp tenant file store"
,
K
(
ret
),
K
(
tenant_id
),
K
(
io_info
));
}
else
if
(
OB_FAIL
(
store
->
write
(
io_info
)))
{
}
else
if
(
OB_FAIL
(
store
_handle
.
get_tenant_store
()
->
write
(
io_info
)))
{
STORAGE_LOG
(
WARN
,
"fail to write the extent"
,
K
(
ret
),
K
(
tenant_id
),
K
(
io_info
));
}
return
ret
;
...
...
@@ -1262,10 +1323,10 @@ int ObTmpFileStore::write(const uint64_t tenant_id, const ObTmpBlockIOInfo& io_i
int
ObTmpFileStore
::
free
(
const
uint64_t
tenant_id
,
ObTmpFileExtent
*
extent
)
{
int
ret
=
OB_SUCCESS
;
ObTmpTenantFileStore
*
store
=
NULL
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
)))
{
ObTmpTenantFileStore
Handle
store_handle
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
_handle
)))
{
STORAGE_LOG
(
WARN
,
"fail to get tmp tenant file store"
,
K
(
ret
),
K
(
tenant_id
),
K
(
*
extent
));
}
else
if
(
OB_FAIL
(
store
->
free
(
extent
)))
{
}
else
if
(
OB_FAIL
(
store
_handle
.
get_tenant_store
()
->
free
(
extent
)))
{
STORAGE_LOG
(
WARN
,
"fail to free extents"
,
K
(
ret
),
K
(
tenant_id
),
K
(
*
extent
));
}
return
ret
;
...
...
@@ -1275,10 +1336,10 @@ int ObTmpFileStore::free(
const
uint64_t
tenant_id
,
const
int64_t
block_id
,
const
int32_t
start_page_id
,
const
int32_t
page_nums
)
{
int
ret
=
OB_SUCCESS
;
ObTmpTenantFileStore
*
store
=
NULL
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
)))
{
ObTmpTenantFileStore
Handle
store_handle
;
if
(
OB_FAIL
(
get_store
(
tenant_id
,
store
_handle
)))
{
STORAGE_LOG
(
WARN
,
"fail to get tmp tenant file store"
,
K
(
ret
),
K
(
tenant_id
));
}
else
if
(
OB_FAIL
(
store
->
free
(
block_id
,
start_page_id
,
page_nums
)))
{
}
else
if
(
OB_FAIL
(
store
_handle
.
get_tenant_store
()
->
free
(
block_id
,
start_page_id
,
page_nums
)))
{
STORAGE_LOG
(
WARN
,
"fail to free"
,
K
(
ret
),
K
(
tenant_id
),
K
(
block_id
),
K
(
start_page_id
),
K
(
page_nums
));
}
return
ret
;
...
...
@@ -1287,19 +1348,12 @@ int ObTmpFileStore::free(
int
ObTmpFileStore
::
free_tenant_file_store
(
const
uint64_t
tenant_id
)
{
int
ret
=
OB_SUCCESS
;
ObTmpTenantFileStore
*
store
=
NULL
;
if
(
OB_FAIL
(
tenant_file_stores_
.
erase_refactored
(
tenant_id
,
&
store
)))
{
if
(
OB_FAIL
(
tenant_file_stores_
.
erase_refactored
(
tenant_id
)))
{
if
(
OB_HASH_NOT_EXIST
==
ret
)
{
ret
=
OB_ENTRY_NOT_EXIST
;
}
else
{
STORAGE_LOG
(
WARN
,
"fail to erase tmp tenant file store"
,
K
(
ret
),
K
(
tenant_id
));
}
}
else
if
(
OB_ISNULL
(
store
))
{
ret
=
OB_ERR_UNEXPECTED
;
STORAGE_LOG
(
WARN
,
"unexpected error, store is null"
,
K
(
ret
));
}
else
{
store
->~
ObTmpTenantFileStore
();
allocator_
.
free
(
store
);
}
return
ret
;
}
...
...
@@ -1315,7 +1369,7 @@ int ObTmpFileStore::get_macro_block_list(common::ObIArray<MacroBlockId>& macro_i
TenantFileStoreMap
::
iterator
iter
;
ObTmpTenantFileStore
*
tmp
=
NULL
;
for
(
iter
=
tenant_file_stores_
.
begin
();
OB_SUCC
(
ret
)
&&
iter
!=
tenant_file_stores_
.
end
();
++
iter
)
{
if
(
OB_ISNULL
(
tmp
=
iter
->
second
))
{
if
(
OB_ISNULL
(
tmp
=
iter
->
second
.
get_tenant_store
()
))
{
ret
=
OB_ERR_UNEXPECTED
;
STORAGE_LOG
(
WARN
,
"fail to iterate tmp tenant file store"
,
K
(
ret
));
}
else
if
(
OB_FAIL
(
tmp
->
get_disk_macro_block_list
(
macro_id_list
)))
{
...
...
@@ -1340,7 +1394,7 @@ int ObTmpFileStore::get_macro_block_list(ObIArray<TenantTmpBlockCntPair>& tmp_bl
for
(
iter
=
tenant_file_stores_
.
begin
();
OB_SUCC
(
ret
)
&&
iter
!=
tenant_file_stores_
.
end
();
++
iter
)
{
TenantTmpBlockCntPair
pair
;
macro_id_list
.
reset
();
if
(
OB_ISNULL
(
tmp
=
iter
->
second
))
{
if
(
OB_ISNULL
(
tmp
=
iter
->
second
.
get_tenant_store
()
))
{
ret
=
OB_ERR_UNEXPECTED
;
STORAGE_LOG
(
WARN
,
"fail to iterate tmp tenant file store"
,
K
(
ret
));
}
else
if
(
OB_FAIL
(
tmp
->
get_disk_macro_block_list
(
macro_id_list
)))
{
...
...
@@ -1371,9 +1425,8 @@ int ObTmpFileStore::get_all_tenant_id(common::ObIArray<uint64_t> &tenant_ids)
tenant_ids
.
reset
();
TenantFileStoreMap
::
iterator
iter
;
SpinRLockGuard
guard
(
lock_
);
for
(
iter
=
tenant_file_stores_
.
begin
();
OB_SUCC
(
ret
)
&&
iter
!=
tenant_file_stores_
.
end
();
++
iter
)
{
if
(
OB_ISNULL
(
iter
->
second
))
{
for
(
iter
=
tenant_file_stores_
.
begin
();
OB_SUCC
(
ret
)
&&
iter
!=
tenant_file_stores_
.
end
();
++
iter
)
{
if
(
OB_ISNULL
(
iter
->
second
.
get_tenant_store
()))
{
ret
=
OB_ERR_UNEXPECTED
;
STORAGE_LOG
(
WARN
,
"fail to iterate tmp tenant file store"
,
K
(
ret
));
}
else
if
(
OB_FAIL
(
tenant_ids
.
push_back
(
iter
->
first
)))
{
...
...
@@ -1384,17 +1437,19 @@ int ObTmpFileStore::get_all_tenant_id(common::ObIArray<uint64_t> &tenant_ids)
return
ret
;
}
int
ObTmpFileStore
::
get_store
(
const
uint64_t
tenant_id
,
ObTmpTenantFileStore
*&
stor
e
)
int
ObTmpFileStore
::
get_store
(
const
uint64_t
tenant_id
,
ObTmpTenantFileStore
Handle
&
handl
e
)
{
int
ret
=
OB_SUCCESS
;
void
*
buf
=
NULL
;
handle
.
reset
();
if
(
OB_UNLIKELY
(
!
is_inited_
))
{
ret
=
OB_NOT_INIT
;
STORAGE_LOG
(
WARN
,
"ObTmpFileStore has not been inited"
,
K
(
ret
),
K
(
tenant_id
));
}
else
{
SpinWLockGuard
guard
(
lock_
);
if
(
OB_FAIL
(
tenant_file_stores_
.
get_refactored
(
tenant_id
,
stor
e
)))
{
if
(
OB_FAIL
(
tenant_file_stores_
.
get_refactored
(
tenant_id
,
handl
e
)))
{
if
(
OB_HASH_NOT_EXIST
==
ret
)
{
ObTmpTenantFileStore
*
store
=
NULL
;
if
(
OB_ISNULL
(
buf
=
allocator_
.
alloc
(
sizeof
(
ObTmpTenantFileStore
))))
{
ret
=
OB_ALLOCATE_MEMORY_FAILED
;
STORAGE_LOG
(
WARN
,
"fail to alloc a buf"
,
K
(
ret
),
K
(
tenant_id
));
...
...
@@ -1406,7 +1461,8 @@ int ObTmpFileStore::get_store(const uint64_t tenant_id, ObTmpTenantFileStore *&s
allocator_
.
free
(
store
);
store
=
NULL
;
STORAGE_LOG
(
WARN
,
"fail to init ObTmpTenantFileStore"
,
K
(
ret
),
K
(
tenant_id
));
}
else
if
(
OB_FAIL
(
tenant_file_stores_
.
set_refactored
(
tenant_id
,
store
)))
{
}
else
if
(
FALSE_IT
(
handle
.
set_tenant_store
(
store
)))
{
}
else
if
(
OB_FAIL
(
tenant_file_stores_
.
set_refactored
(
tenant_id
,
handle
)))
{
STORAGE_LOG
(
WARN
,
"fail to set tenant_file_stores_"
,
K
(
ret
),
K
(
tenant_id
));
}
}
else
{
...
...
@@ -1421,13 +1477,6 @@ void ObTmpFileStore::destroy()
{
ObTmpPageCache
::
get_instance
().
destroy
();
TenantFileStoreMap
::
iterator
iter
;
ObTmpTenantFileStore
*
tmp
=
NULL
;
for
(
iter
=
tenant_file_stores_
.
begin
();
iter
!=
tenant_file_stores_
.
end
();
++
iter
)
{
if
(
OB_NOT_NULL
(
tmp
=
iter
->
second
))
{
tmp
->~
ObTmpTenantFileStore
();
allocator_
.
free
(
tmp
);
}
}
tenant_file_stores_
.
destroy
();
file_handle_
.
reset
();
allocator_
.
destroy
();
...
...
src/storage/blocksstable/ob_tmp_file_store.h
浏览文件 @
4891d24b
...
...
@@ -255,10 +255,10 @@ private:
DISALLOW_COPY_AND_ASSIGN
(
ObTmpTenantMacroBlockManager
);
};
class
ObTmpTenantFileStore
{
class
ObTmpTenantFileStore
final
{
public:
ObTmpTenantFileStore
();
virtual
~
ObTmpTenantFileStore
();
~
ObTmpTenantFileStore
();
int
init
(
const
uint64_t
tenant_id
,
const
ObStorageFileHandle
&
file_handle
);
void
destroy
();
int
alloc
(
const
int64_t
dir_id
,
const
uint64_t
tenant_id
,
const
int64_t
size
,
ObTmpFileExtent
&
extent
);
...
...
@@ -275,6 +275,8 @@ public:
{
return
tmp_block_manager_
.
get_block_size
();
}
void
inc_ref
();
void
dec_ref
();
private:
int
read_page
(
ObTmpMacroBlock
*
block
,
ObTmpBlockIOInfo
&
io_info
,
ObTmpFileIOHandle
&
handle
);
...
...
@@ -297,10 +299,30 @@ private:
common
::
ObConcurrentFIFOAllocator
allocator_
;
common
::
SpinRWLock
lock_
;
bool
is_inited_
;
volatile
int64_t
ref_cnt_
;
DISALLOW_COPY_AND_ASSIGN
(
ObTmpTenantFileStore
);
};
struct
ObTmpTenantFileStoreHandle
final
{
public:
ObTmpTenantFileStoreHandle
();
~
ObTmpTenantFileStoreHandle
();
ObTmpTenantFileStoreHandle
(
const
ObTmpTenantFileStoreHandle
&
other
);
ObTmpTenantFileStoreHandle
&
operator
=
(
const
ObTmpTenantFileStoreHandle
&
other
);
void
set_tenant_store
(
ObTmpTenantFileStore
*
store
);
bool
is_empty
()
const
;
bool
is_valid
()
const
;
void
reset
();
OB_INLINE
ObTmpTenantFileStore
*
get_tenant_store
()
const
{
return
tenant_store_
;
}
private:
ObTmpTenantFileStore
*
tenant_store_
;
};
class
ObTmpFileStore
{
public:
typedef
common
::
hash
::
HashMapPair
<
uint64_t
,
int64_t
>
TenantTmpBlockCntPair
;
...
...
@@ -327,7 +349,7 @@ public:
private:
ObTmpFileStore
();
virtual
~
ObTmpFileStore
();
int
get_store
(
const
uint64_t
tenant_id
,
ObTmpTenantFileStore
*&
stor
e
);
int
get_store
(
const
uint64_t
tenant_id
,
ObTmpTenantFileStore
Handle
&
handl
e
);
private:
static
const
uint64_t
STORE_HASH_BUCKET_NUM
=
1543L
;
...
...
@@ -336,7 +358,7 @@ private:
static
const
int64_t
BLOCK_SIZE
=
common
::
OB_MALLOC_NORMAL_BLOCK_SIZE
;
static
const
int
TMP_FILE_PAGE_CACHE_PRIORITY
=
1
;
static
const
int
TMP_FILE_BLOCK_CACHE_PRIORITY
=
1
;
typedef
common
::
hash
::
ObHashMap
<
uint64_t
,
ObTmpTenantFileStore
*
,
common
::
hash
::
SpinReadWriteDefendMode
>
typedef
common
::
hash
::
ObHashMap
<
uint64_t
,
ObTmpTenantFileStore
Handle
,
common
::
hash
::
SpinReadWriteDefendMode
>
TenantFileStoreMap
;
TenantFileStoreMap
tenant_file_stores_
;
ObStorageFileHandle
file_handle_
;
...
...
unittest/storage/blocksstable/test_tmp_file.cpp
浏览文件 @
4891d24b
...
...
@@ -622,9 +622,9 @@ TEST_F(TestTmpFile, test_big_file)
STORAGE_LOG
(
INFO
,
"test_big_file"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -653,9 +653,9 @@ TEST_F(TestTmpFile, test_multi_small_file_single_thread_read_write)
STORAGE_LOG
(
INFO
,
"test_multi_small_file_single_thread_read_write"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -682,9 +682,9 @@ TEST_F(TestTmpFile, test_multi_small_file_multi_thread_read_write)
STORAGE_LOG
(
INFO
,
"test_multi_small_file_multi_thread_read_write"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -755,9 +755,9 @@ TEST_F(TestTmpFile, test_inner_read_offset_and_seek)
STORAGE_LOG
(
INFO
,
"test_inner_read_offset_and_seek"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -786,9 +786,9 @@ TEST_F(TestTmpFile, test_single_file_single_thread_read_write)
STORAGE_LOG
(
INFO
,
"test_single_file_single_thread_read_write"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -863,9 +863,9 @@ TEST_F(TestTmpFile, test_aio_read_and_write)
STORAGE_LOG
(
INFO
,
"test_aio_read_and_write"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -902,9 +902,9 @@ TEST_F(TestTmpFile, test_100_small_files)
}
STORAGE_LOG
(
INFO
,
"test_1000_small_files"
);
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -936,9 +936,9 @@ TEST_F(TestTmpFile, test_single_file_multi_thread_read_write)
STORAGE_LOG
(
INFO
,
"test_single_file_multi_thread_read_write"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -965,9 +965,9 @@ TEST_F(TestTmpFile, test_multi_file_single_thread_read_write)
STORAGE_LOG
(
INFO
,
"test_multi_file_single_thread_read_write"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -994,9 +994,9 @@ TEST_F(TestTmpFile, test_multi_file_multi_thread_read_write)
STORAGE_LOG
(
INFO
,
"test_multi_file_multi_thread_read_write"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -1023,9 +1023,9 @@ TEST_F(TestTmpFile, test_write_not_macro_size)
STORAGE_LOG
(
INFO
,
"test_write_not_macro_size"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -1101,9 +1101,9 @@ TEST_F(TestTmpFile, test_write_less_than_macro_block_size)
STORAGE_LOG
(
INFO
,
"test_write_less_than_macro_block_size"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -1197,9 +1197,9 @@ TEST_F(TestTmpFile, test_write_more_than_one_macro_block)
STORAGE_LOG
(
INFO
,
"test_write_more_than_one_macro_block"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -1275,13 +1275,13 @@ TEST_F(TestTmpFile, test_single_dir_two_file)
cmp
=
memcmp
(
handle2
.
get_buffer
(),
write_buf
,
macro_block_size
+
256
);
ASSERT_EQ
(
0
,
cmp
);
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObTmpFileManager
::
get_instance
().
remove
(
fd_1
);
ObTmpFileManager
::
get_instance
().
remove
(
fd_2
);
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
}
/*TEST_F(TestTmpFile, test_iter_end)
...
...
@@ -1373,9 +1373,9 @@ TEST_F(TestTmpFile, test_single_dir_multi_file)
STORAGE_LOG
(
INFO
,
"test_single_dir_multi_file"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
io_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -1481,9 +1481,9 @@ TEST_F(TestTmpFile, test_handle_double_wait)
STORAGE_LOG
(
INFO
,
"test_handle_double_wait"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
@@ -1578,10 +1578,10 @@ TEST_F(TestTmpFile, test_sql_workload)
STORAGE_LOG
(
INFO
,
"test_sql_workload"
);
STORAGE_LOG
(
INFO
,
"io time"
,
K
((
write_size
*
cnt
)
/
(
1024
*
1024
*
1024
)),
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
*
store
=
NULL
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
);
store
->
print_block_usage
();
STORAGE_LOG
(
INFO
,
"io time"
,
K
((
write_size
*
cnt
)
/
(
1024
*
1024
*
1024
)),
K
(
write_time
),
K
(
read_time
));
ObTmpTenantFileStore
Handle
store_handle
;
OB_TMP_FILE_STORE
.
get_store
(
1
,
store
_handle
);
store
_handle
.
get_tenant_store
()
->
print_block_usage
();
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_ctx_memory_usage
(
1
);
ObMallocAllocator
::
get_instance
()
->
print_tenant_memory_usage
(
500
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录