• openGauss学习笔记-126 openGauss 数据库管理-设置账本数据库-归档账本数据库


    openGauss学习笔记-126 openGauss 数据库管理-设置账本数据库-归档账本数据库

    126.1 前提条件

    • 系统中需要有审计管理员或者具有审计管理员权限的角色。
    • 数据库正常运行,并且对防篡改数据库执行了一系列增、删、改等操作,保证在查询时段内有账本操作记录结果产生。
    • 数据库已经正确配置审计文件的存储路径audit_directory。

    126.2 背景信息

    • 账本数据库归档功能目前提供两种校验接口,分别为:ledger_hist_archive(text…和ledger_gchain_archive(vo…。账本数据库接口仅审计管理员可以调用。

    • 归档用户历史表的接口为pg_catalog.ledger_hist_archive,操作为:

      SELECT pg_catalog.ledger_hist_archive(schema_name text,table_name text);
      
      • 1

      如果归档成功,函数返回t,反之则返回f。

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

      SELECT pg_catalog.ledger_gchain_archive();
      
      • 1

      如果归档成功,函数返回t,反之则返回f。

    126.3 操作步骤

    1. 对指定用户历史表进行归档操作。

      openGauss=# SELECT pg_catalog.ledger_hist_archive('ledgernsp', 'usertable');
      
      • 1

      执行结果如下:

       ledger_hist_archive
      ---------------------
       t
      (1 row)
      
      • 1
      • 2
      • 3
      • 4

      用户历史表将归档为一条数据:

      openGauss=# SELECT * FROM blockchain.ledgernsp_usertable_hist;
       rec_num |     hash_ins     |     hash_del     |             pre_hash
      ---------+------------------+------------------+----------------------------------
             3 | e78e75b00d396899 | 8fcd74a8a6a4b484 | fd61cb772033da297d10c4e658e898d7
      (1 row)
      
      • 1
      • 2
      • 3
      • 4
      • 5

      该结果表明当前节点用户历史表导出成功。

    2. 执行全局区块表导出操作。

      openGauss=# SELECT pg_catalog.ledger_gchain_archive();
      
      • 1

      执行结果如下:

       ledger_gchain_archive
      -----------------------
       t
      (1 row)
      
      • 1
      • 2
      • 3
      • 4

      全局历史表将以用户表为单位归档为N(用户表数量)条数据:

      openGauss=# SELECT * FROM gs_global_chain;
       blocknum |  dbname  | username |           starttime           | relid |  relnsp   |  relname  |     relhash      |            globalhash            | txcommand
      ----------+----------+----------+-------------------------------+-------+-----------+-----------+------------------+----------------------------------+-----------
              1 | postgres | libc     | 2021-05-10 19:59:38.619472+08 | 16388 | ledgernsp | usertable | 57c101076694b415 | be82f98ee68b2bc4e375f69209345406 | Archived.
      (1 row)
      
      • 1
      • 2
      • 3
      • 4
      • 5

      该结果表明,当前节点全局区块表导出成功。

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

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

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

    图片

  • 相关阅读:
    源码编译安装LNMP
    Effective C++改善程序与设计的55个具体做法 2. 构造/析构/赋值运算
    PyTorch入门学习(八):神经网络-卷积层
    item_search - 根据关键词获取义乌购商品列表
    PS 证件照换底色
    游戏海外运营需要准备什么?
    ESP32建立TCP连接
    Hadoop_HDFS笔记2(HDFS的API操作,HDFS的读写流程(面试重点))
    Python:实现perceptron算法(附完整源码)
    保驾护航,嘉为蓝鲸助力某科技公司AD域故障恢复实记
  • 原文地址:https://blog.csdn.net/shuchaoyang/article/details/134484385