暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

openGauss学习笔记-127 openGauss 数据库管理-设置账本数据库-修复账本数据库

原创 shuchaoyang 2024-01-21
142

openGauss学习笔记-127 openGauss 数据库管理-设置账本数据库-修复账本数据库

127.1 前提条件

  • 系统中需要有审计管理员或者具有审计管理员权限的角色。

  • 数据库正常运行,并且对防篡改数据库执行了一系列增、删、改等操作,保证在查询时段内有账本操作记录结果产生。

127.2 背景信息

  • 当在异常情况或表被损坏时需要使用账本数据库的函数章节中的ledger_gchain_repair(text, text)或ledger_hist_repair(text, text)接口对全局区块表或用户历史表进行修复,修复后调用全局区块表或用户历史表校验接口结果为true。

  • 修复用户历史表的接口为pg_catalog.ledger_hist_repair,操作为:

    SELECT pg_catalog.ledger_hist_repair(schema_name text,table_name text);

    如果修复成功,函数返回修复过程中用户历史表hash的增量。

  • 归档全局区块表的接口为pg_catalog.ledger_gchain_repair,操作为:

    SELECT pg_catalog.ledger_gchain_repair(schema_name text,table_name text);

    如果修复成功,函数返回修复过程中全局区块表hash的增量。

127.3 操作步骤

  1. 执行历史表修复操作。

    openGauss=# SELECT pg_catalog.ledger_hist_repair('ledgernsp', 'usertable');

    查询结果如下:

     ledger_hist_repair
    --------------------
    84e8bfc3b974e9cf
    (1 row)

    该结果表明当前节点用户历史表修复成功,修复造成的用户历史表hash增量为84e8bfc3b974e9cf。

  2. 执行全局区块表修复操作。

    openGauss=# SELECT pg_catalog.ledger_gchain_repair('ledgernsp', 'usertable');

    查询结果如下:

     ledger_gchain_repair
    ----------------------
    a41714001181a294
    (1 row)

    该结果表明,全局区块表修复成功,且插入一条修复数据,其hash值为a41714001181a294。

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

图片

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

文章被以下合辑收录

评论