金仓数据库KingbaseES中WalMiner接口使用

WalMiner的限制与约束

  • WalMiner工具的使用必须以数据库超级用户执行。
  • 数据库能正常运行。
  • full_page_writes必须为开启状态。
  • 拥有完整连续的WAL日志。
  • 能导出正常使用的数据字典。
  • 解析过程中,日志所需数据字典没有发生改变。
  • 不支持DDL的解析。
  • 日志文件或history文件损坏的情况下,有可能解析不出数据。

一、创建扩展

在对应的database下安装walminer扩展。

mydb=>create extension walminer;

CREATE EXTENSION

二、添加日志

添加日志时,可以添加文件夹或文件,可以多次添加多个不同的目录,WalMiner会自动根据日志文件名称进行排序和去重。比如可以同时添加在线日志目录和归档日志目录。添加文件时,会对文件进行判断,如果不是WAL日志,则会报错。

如下,添加了wal和归档两个目录下的日志

mydb=# select walminer_wal_add('sys_wal');

walminer_wal_add


5 file add success

(1 row)

mydb=# select walminer_wal_add('/Kingbase/arch');

walminer_wal_add


3 file add success

(1 row)

三、展示日志列表

mydb=# select walminer_wal_list();

walminer_wal_list


(/Kingbase/arch/00000001000000000000000A)

(/Kingbase/arch/00000001000000000000000B)

(/Kingbase/arch/00000001000000000000000C)

(/Kingbase/ES/V9/data/sys_wal/00000001000000000000000D)

(/Kingbase/ES/V9/data/sys_wal/00000001000000000000000E)

(/Kingbase/ES/V9/data/sys_wal/00000001000000000000000F)

(/Kingbase/ES/V9/data/sys_wal/000000010000000000000010)

(/Kingbase/ES/V9/data/sys_wal/000000010000000000000011)

(8 rows)

#删除已经添加的日志,可以删除单个文件,也可以删除文件夹,可以多次执行

select walminer_wal_remove('sys_wal/000000010000000000000011');

或者

select walminer_wal_remove('sys_wal');

四、数据解析

1. 普通解析

walminer_al会解析已加入的所有WAL日志,如果没有添加WAL日志,则解析data/sys_wal目录下所有WAL日志,解析过程中遇到WAL日志错误、或WAL日志不连续,会在错误或不连续的地方停止解析。

mydb=# select walminer_all();

walminer_all


sys_miner success

(1 row)

2. 时间范围解析

根据时间范围解析,在add的WAL日志中查找对应时间范围的WAL记录。

select walminer_by_time('2026-01-08 15::30', '2026-01-08 16:10:00');

在时间范围解析中,如果开始时间设置为空,则从已加入的WAL日志列表中第一个日志的第一个LSN开始解析。

3. LSN范围解析

根据LSN范围解析,在add的WAL日志中查找对应LSN范围的WAL记录。

select walminer_by_lsn('0/010000A0', '0/016E6578');

4. 单表解析

--开始时间/LSN --结束时间/LSN 是否精准解析 --表OID。单表解析时,必须指定是否为精准解析。

select walminer_by_time('2026-01-08 15::30', '2026-01-08 16:10:00','false', 16452);

解析完成后会自动删除生成的中间文件、已添加的WAL日志、已导入的数据字典等。

五、查看解析结果

mydb=# select * from walminer_contents;

walminer_contents表字段描述信息:

|------------|--------------------------|-------------------------------|
| 字段名称 | 字段类型 | 字段描述 |
| sqlno | integer | SQL语句在事务里的编号 |
| xid | bigint | 当前事务的xid |
| topxid | bigint | 父事务的xid |
| sqlkind | integer | SQL语句类型(INSERT/DELETE/UPDATE) |
| minerd | boolean | 是否能解析 |
| timestamp | timestamp with time zone | 事务提交时间 |
| op_text | text | redo语句 |
| undo_text | text | undo语句 |
| complete | boolean | 事务是否已完成 |
| schema | text | 模式名 |
| relation | text | 表名 |
| start_lsn | sys_lsn | 事务开始的LSN号 |
| commit_lsn | sys_lsn | 事务提交时的LSN号 |

最终,结束解析,结束解析时,会清空解析过程中生成的中间文件。

六、释放内存和临时资源

mydb=# select walminer_stop();

walminer_stop


walminer stoped!

(1 row)

七、解析其他数据库的WAL日志

解析其他库的日志暂不支持解析自定义数据类型,如果其他库的WAL日志中存在自定义数据类型,而本库没有对应的数据类型则会解析失败。

1. 从其他数据库导出数据字典

复制代码
-- 导出数据字典

kingbase=# select walminer_build_dictionary('/kingbase/dict');

walminer_build_dictionary


Dictionary build success!

(1 row)

导出的数据字典名称为:dict

kingbase@opengaussdb Kingbase\]$ ll /Kingbase/dict total 1292 -rw------- 1 kingbase kingbase 1322744 Jan 8 14:42 dictionary.d #### **2. 导入其他数据库的数据字典** ``` -- 导入数据字典 ``` kingbase=# select walminer_load_dictionary('/kingbase/dict'); walminer_load_dictionary -------------------------- Dictionary load success! (1 row) 导入其他数据库的wal日志解析,除了增加本章节1、2步骤导出导入数据字典步骤外,其他步骤与第1、2、3、4、5、6章节相同,不再重复赘述。 ### **总结** Walminer是一个功能强大的工具,用于解析和分析数据库的wal日志文件,以提取有用的事务信息和数据操作,无论是故障恢复、数据版本控制还是数据分析,Walminer接口都是一个强大的工具。

相关推荐
爱潜水的小L15 小时前
自学嵌入式day43,商城网页
数据库·oracle
IvorySQL15 小时前
PostgreSQL 的 SQL 查询之旅
数据库·人工智能·postgresql·开源
musenh15 小时前
redis和jedis
数据库·redis·缓存
莳花微语15 小时前
磐维数据库的权限使用
数据库
win x16 小时前
Redis 主从复制
java·数据库·redis
周末吃鱼16 小时前
MySQL CTE:SQL查询新模式
数据库·sql·mysql
木风小助理16 小时前
解读 SQL 累加计算:从传统方法到窗口函数
大数据·数据库·sql
8号看台17 小时前
ORA-01017: 用户名/口令无效; 登录被拒绝
数据库·oracle
计算机毕设VX:Fegn089517 小时前
计算机毕业设计|基于springboot + vue在线音乐播放系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计