当前位置: 首页 > wzjs >正文

做漫画网站 漫画哪找如何做企业网页

做漫画网站 漫画哪找,如何做企业网页,武汉外包seo公司,宝塔做网站安全吗1. 问题现象:备库升主后查询的WAL文件名时间线不符 某次主备切换后,执行以下操作: 原主库时间线为00000001,备库正常同步。 记录一个lsn和对应的wal日志 select sys_current_wal_lsn(); SELECT sys_walfile_name(0/BD49920);主…
1. 问题现象:备库升主后查询的WAL文件名时间线不符

某次主备切换后,执行以下操作:

  1. 原主库时间线为00000001,备库正常同步。
    记录一个lsn和对应的wal日志
select sys_current_wal_lsn();
SELECT sys_walfile_name('0/BD49920');

在这里插入图片描述
在这里插入图片描述

  1. 主库故障,触发备库升主,新主库时间线变为00000002
  2. 在新主库上,尝试查询旧LSN0/BD49920)对应的WAL文件名:
    SELECT sys_walfile_name('0/BD49920');
    -- 返回结果:00000002000000000000000B
    

在这里插入图片描述

  1. 检查旧主库的WAL日志,发现实际文件名应为00000001000000000000000B
    现象总结
    函数返回的时间线(00000002)与LSN实际所属的时间线(00000001)不符!

2. 问题分析:为什么会时间线对不上?
2.1 时间线的核心作用
  • **时间线(Timeline)**是kingbaseES的“版本分支标识”。
  • 每次主备切换会生成新时间线(如0000000100000002),防止WAL日志覆盖或混淆历史数据分支。
  • 关键规则:新时间线的WAL文件名必须包含新的时间线号,且旧时间线的WAL日志会保留。
2.2 sys_walfile_name()的设计限制
  • 函数逻辑:仅通过数学公式计算LSN对应的文件名,不检查历史时间线!
    文件名 = 时间线(8位) + 逻辑日志号(8位) + 段号(8位)
    
  • 存在的问题:函数输出的时间线部分始终是当前数据库的时间线,而非LSN实际所属的时间线。
  • 本例问题:新主库时间线为00000002,函数强制将任何LSN的时间线部分填充为00000002,导致结果错误。
2.3 时间线切换记录在哪里?
  • 每次时间线切换会生成.history文件(如sys_wal/00000002.history),记录时间线切换点的LSN。
  • 此文件是追踪LSN与时间线映射关系的唯一依据,但sys_walfile_name()未关联此信息!
    在这里插入图片描述

3. 解决方案:如何正确获取历史LSN对应的WAL文件名?
3.1 手动查询时间线历史

定位时间线切换点

-- 查询新时间线对应的.history文件
SELECT * FROM sys_read_file('pg_wal/00000003.history') AS tli_history;

输出示例
在这里插入图片描述

  • 含义:时间线00000002从LSN 0/D0000A0开始生效。
  • 若目标LSN(如0/BD49920)小于0/D0000A0,则属于旧时间线00000001
3.2 使用工具解析WAL元数据

通过sys_waldump直接解析WAL文件,查看LSN与时间线的真实关系:

./sys_waldump ../data/sys_wal/00000001000000000000000B

输出中会明确显示时间线信息:

[kingbase@localhost bin]$ ./sys_waldump ../data/sys_wal/00000001000000000000000B |grep 'BD49920'
rmgr: Heap        len (rec/tot):     56/  2226, tx:       1131, lsn: 0/0BD49920, prev 0/0BD498F0, desc: INSERT off 177 flags 0x00, blkref #0: rel 1663/14731/16467 blk 4424 FPW
rmgr: Heap        len (rec/tot):     59/    59, tx:       1131, lsn: 0/0BD4A1F0, prev 0/0BD49920, desc: INSERT off 178 flags 0x00, blkref #0: rel 1663/14731/16467 blk 4424...
3.3 理解函数的使用场景
  • 适用场景:查询当前时间线下新生成的LSN对应的WAL文件名(例如当前事务的LSN)。
  • 不适用场景:查询历史LSN或跨时间线的WAL文件名。

4. 注意事项
  1. 主备切换后的WAL生成规则
    • 新主库生成的WAL文件名时间线号一定比旧主库大。
    • 旧时间线的WAL文件不会被删除,但新主库不会写入旧时间线文件。
  2. 若使用sys_walfile_name()查询历史LSN需注意
    • 该函数仅用于计算,不关联历史时间线数据。

5. 总结
  • 核心原因sys_walfile_name()函数设计上不关联时间线历史,仅依赖当前时间线生成文件名。
  • 正确姿势
    • 查询历史LSN时,需结合.history文件或工具解析。
    • 将该函数仅用于当前时间线的LSN计算(如监控当前WAL生成状态)。
http://www.dtcms.com/wzjs/516065.html

相关文章:

  • 怎们自己做网站百度seo公司一路火
  • 河北省建设厅网站怎么登陆售卖链接
  • 最珠海appseo从0到1怎么做
  • 定制鞋子哪个网站好爱站网长尾关键词挖掘工具的作用
  • 安徽工程建设信息网站进皖企业百度seo教程
  • 二手书的网站建设朋友圈广告代理商官网
  • 智慧团建登录入口官网电脑版韶关seo
  • 手机网站导航设计360安全网址
  • 做网站图片切图是什么重庆好的seo平台
  • 网页图片代码合肥seo网站建设
  • 做营销网站视频seo外包方法
  • 西安公司网站建设哪家专业余姚关键词优化公司
  • 网站布局软件网站seo培训
  • 化州网站开发公司关键词优化排名要多少钱
  • 做网站难怎么做个网站
  • 如何做新网站保留域名搜索引擎优化关键词选择的方法有哪些
  • 西安360免费做网站水果网络营销推广方案
  • 库尔勒网站建设seo公司重庆
  • 网站做自动群发百度搜录宁波网络推广产品服务
  • 赤峰企业网站建设网站搜索引擎优化主要方法
  • 辽宁省城乡住房建设厅网站惠州seo收费
  • dw做简易表格网站怎么做百度搜索排名
  • 网页制作培训心得优化营商环境条例解读
  • 公司没注册可以做网站吗设计培训班学费一般多少
  • 网站备案万网购物网站制作
  • 深圳住建设局网站公租房广州seo关键词优化是什么
  • 有什么做房屋装修的网站在线看seo网站
  • 淘宝网站建设图片素材建站宝盒
  • 珠海做网站最好的公司有哪些31省市新增疫情最新消息
  • 做直播哪个网站好拉新app推广平台排名