Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Metz
oceanbase
提交
33f67070
O
oceanbase
项目概览
Metz
/
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看板
提交
33f67070
编写于
3月 10, 2022
作者:
S
SanmuWangZJU
提交者:
LINGuanRen
3月 10, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[virtual_table] add column to expose the commit timestamp of eldest clog
上级
acaa03ed
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
37 addition
and
1 deletion
+37
-1
src/observer/virtual_table/ob_all_virtual_server_clog_stat.cpp
...bserver/virtual_table/ob_all_virtual_server_clog_stat.cpp
+19
-0
src/observer/virtual_table/ob_all_virtual_server_clog_stat.h
src/observer/virtual_table/ob_all_virtual_server_clog_stat.h
+2
-1
src/share/inner_table/ob_inner_table_schema.11051_11100.cpp
src/share/inner_table/ob_inner_table_schema.11051_11100.cpp
+15
-0
src/share/inner_table/ob_inner_table_schema_def.py
src/share/inner_table/ob_inner_table_schema_def.py
+1
-0
未找到文件。
src/observer/virtual_table/ob_all_virtual_server_clog_stat.cpp
浏览文件 @
33f67070
...
...
@@ -149,6 +149,25 @@ int ObAllVirtualServerClogStat::inner_get_next_row(ObNewRow*& row)
cells
[
cell_idx
].
set_varchar
(
ObZoneStatus
::
get_status_str
(
locality_info
.
local_zone_status_
));
break
;
}
case
SVR_MIN_LOG_TIMESTAMP
:
{
if
(
OB_ISNULL
(
clog_mgr
))
{
cells
[
cell_idx
].
set_int
(
OB_INVALID_TIMESTAMP
);
}
else
{
// display server_min_log_ts 60s ahead of ts get from clog_mgr
static
int64_t
DISPLAY_AHEAD_TIME
=
60
*
1000
*
1000
;
int64_t
svr_min_log_ts
=
OB_INVALID_TIMESTAMP
;
if
(
OB_FAIL
(
clog_mgr
->
get_server_min_log_ts
(
svr_min_log_ts
)))
{
SERVER_LOG
(
WARN
,
"get_svr_min_log_ts failed"
,
KR
(
ret
),
K
(
svr_min_log_ts
));
svr_min_log_ts
=
OB_INVALID_TIMESTAMP
;
ret
=
OB_SUCCESS
;
}
else
{
// svr_min_log_ts is min clog ts on this server, the log may not confirmed
svr_min_log_ts
+=
DISPLAY_AHEAD_TIME
;
}
cells
[
cell_idx
].
set_int
(
svr_min_log_ts
);
}
break
;
}
default:
{
ret
=
OB_ERR_UNEXPECTED
;
SERVER_LOG
(
WARN
,
"invalid column id"
,
K
(
ret
),
K
(
cell_idx
),
K
(
output_column_ids_
),
K
(
col_id
));
...
...
src/observer/virtual_table/ob_all_virtual_server_clog_stat.h
浏览文件 @
33f67070
...
...
@@ -42,7 +42,8 @@ private:
IDC
,
ZONE_TYPE
,
MERGE_STATUS
,
ZONE_STATUS
ZONE_STATUS
,
SVR_MIN_LOG_TIMESTAMP
};
common
::
ObAddr
*
addr_
;
common
::
ObString
ipstr_
;
...
...
src/share/inner_table/ob_inner_table_schema.11051_11100.cpp
浏览文件 @
33f67070
...
...
@@ -6454,6 +6454,21 @@ int ObInnerTableSchema::all_virtual_server_clog_stat_schema(ObTableSchema &table
false
,
//is_nullable
false
);
//is_autoincrement
}
if
(
OB_SUCC
(
ret
))
{
ADD_COLUMN_SCHEMA
(
"svr_min_log_timestamp"
,
//column_name
++
column_id
,
//column_id
0
,
//rowkey_id
0
,
//index_id
0
,
//part_key_pos
ObIntType
,
//column_type
CS_TYPE_INVALID
,
//column_collation_type
sizeof
(
int64_t
),
//column_length
-
1
,
//column_precision
-
1
,
//column_scale
false
,
//is_nullable
false
);
//is_autoincrement
}
if
(
OB_SUCC
(
ret
))
{
table_schema
.
get_part_option
().
set_part_func_type
(
PARTITION_FUNC_TYPE_HASH
);
if
(
OB_FAIL
(
table_schema
.
get_part_option
().
set_part_expr
(
"hash (addr_to_partition_id(svr_ip, svr_port))"
)))
{
...
...
src/share/inner_table/ob_inner_table_schema_def.py
浏览文件 @
33f67070
...
...
@@ -7233,6 +7233,7 @@ def_table_schema(
('zone_type', 'varchar:MAX_ZONE_INFO_LENGTH'),
('merge_status', 'varchar:MAX_ZONE_INFO_LENGTH'),
('zone_status', 'varchar:MAX_ZONE_INFO_LENGTH'),
('svr_min_log_timestamp', 'int'),
],
partition_columns = ['svr_ip', 'svr_port'],
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录