【openGauss/MogDB使用mog_xlogdump解析 xlog文件内容】

2024-01-22 13:52

本文主要是介绍【openGauss/MogDB使用mog_xlogdump解析 xlog文件内容】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

openGauss/MogDB的mog_xlogdump工具类似于PostgreSQL的pg_xlogdump/pg_waldump,可以解析xlog日志,获取xlog里的相关记录。可以通过MogDB的官网下载对应的版本使用,
https://www.mogdb.io/downloads/mogdb

一、 创建表并增加主键(模拟数据)

omm1@ubuntu-linux-22-04-desktop:~$ gsql -r
gsql ((openGauss 3.0.5 build b54d05de) compiled at 2023-09-23 09:23:38 commit 0 last mr )
Non-SSL connection (SSL connection is recommended when requiring high-security)
Type "help" for help.openGauss=# create table test_tab1(id int, name varchar(20),insert_time timestamp not null default now());
CREATE TABLE
openGauss=# \d test_tab1
​           Table "public.test_tab1"Column  |      Type       |    Modifiers
-------------+-----------------------------+------------------------id     | integer           |name    | character varying(20)    |insert_time | timestamp without time zone | not null default now()openGauss=# show wal_level ;wal_level
-------------hot_standby
(1 row)openGauss=# alter table test_tab1 add primary key(id);
NOTICE: ALTER TABLE / ADD PRIMARY KEY will create implicit index "test_tab1_pkey" for table "test_tab1"
ALTER TABLE
openGauss=# \d test_tab1
​           Table "public.test_tab1"Column  |      Type       |    Modifiers
-------------+-----------------------------+------------------------id     | integer           | not nullname    | character varying(20)    |insert_time | timestamp without time zone | not null default now()
Indexes:"test_tab1_pkey" PRIMARY KEY, btree (id) TABLESPACE pg_default

在这里插入图片描述

二、插入数据(模拟数据)

openGauss=# insert into test_tab1 values(1,'ysl');
INSERT 0 1//查看数据的xmin,xmax,通过xmin可以看到这条数据属于事务13263openGauss=# select xmin,xmax,* from test_tab1;xmin | xmax | id | name |    insert_time
-------+------+----+------+----------------------------13263 |  0 | 1 | ysl | 2023-12-15 14:49:35.975264
(1 row)//查看表的filenodeopenGauss=# select pg_relation_filenode('test_tab1');pg_relation_filenode
----------------------
​        16384
(1 row)//看到当前使用的wal文件对应的xlog_location
openGauss=# select pg_current_xlog_location();pg_current_xlog_location
-------------------------0/22B8508
(1 row)//可以用如下直接转成使用的xlog文件openGauss=# select pg_xlogfile_name(pg_current_xlog_location());pg_xlogfile_name
--------------------------000000010000000000000002
(1   row)

在这里插入图片描述

三、使用mog_xlogdump解析xlog文件

//指定事物id,表应的filenode

mog_xlogdump -x 13263 -o 16384 -R int,varchar,timestamp 000000010000000000000002'insert','tuple':{'int':'1','varchar':'ysl','timestamp':'2023-12-15 14:49:35.975264'}mog_xlogdump: FATAL: error in WAL record at 0/22B8B28: invalid record length at 0/22B8BC8: wanted 32, got 0

在这里插入图片描述

//或者不指定事物id,只指定表对应的filenode

 mog_xlogdump -o 16384 -R int,varchar,timestamp 000000010000000000000002'insert','tuple':{'int':'1','varchar':'ysl','timestamp':'2023-12-15 14:49:35.975264'}mog_xlogdump: FATAL: error in WAL record at 0/22B8C48: invalid record length at 0/22B8CE8: wanted 32, got 0

在这里插入图片描述

四、关于REPLICA IDENTITY和解码数据对比

REPLICA IDENTITY {DEFAULT | USING INDEX index_name | FULL | NOTHING} 调整逻辑复制时写入WAL日志中的信息量,该选项仅在wal_level配置为logical时才有效。

当原数据表发生更新时,默认的逻辑复制流只包含主键的历史记录,如果需要输出所需字段更新或删除的历史记录,可修改本参数。

  • DEFAULT(非系统表的默认值): 会记录主键字段的旧值。
  • USING INDEX : 会记录名为index_name索引包含的字段的旧值,索引的所有列必须NOT NULL。
  • FULL : 记录了所有列的旧值。
  • NOTHING(系统表默认值): 不记录旧值的信息。

在REPLICA IDENTITY默认未修改的情况下,update的解码数据对比如下

数据更新:未设置wal_level=logical,未修改replica identity

‘update’,‘new_tuple’:{‘(null)’:‘2’,‘(null)’:‘tt’,‘(null)’:‘2022-04-25 20:05:28.159008’}

数据更新:设置wal_level=logical,未修改replica identity

‘update’,‘new_tuple’:{‘(null)’:‘2’,‘(null)’:‘ttt’,‘(null)’:‘2022-04-25 20:05:28.159008’}

更新非主键列

‘update’,‘new_tuple’:{‘(null)’:‘2’,‘(null)’:‘tttt’,‘(null)’:‘2022-04-25 20:05:28.159008’}

更新主键列

‘update’,‘old_tuple’:{‘(null)’:‘2’,},‘new_tuple’:{‘(null)’:‘3’,‘(null)’:‘ttttt’,‘(null)’:‘2022-04-25 20:05:28.159008’}

这篇关于【openGauss/MogDB使用mog_xlogdump解析 xlog文件内容】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/633183

相关文章

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一