• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    postgresql之使用lsn 获取 wal文件名的实例

    10.0及以后版本:

    pg_walfile_name()

    用法:

    postgres=# select pg_current_wal_lsn(),
         pg_walfile_name(pg_current_wal_lsn()),             
         pg_walfile_name_offset(pg_current_wal_lsn());
     pg_current_wal_lsn |  pg_walfile_name  |  pg_walfile_name_offset  
    --------------------+--------------------------+---------------------------------
     2/C000840   | 00000001000000020000000C | (00000001000000020000000C,2112)
    (1 row)

    注:

    pg_current_wal_lsn():获得当前wal日志写入位置。

    pg_walfile_name(lsn pg_lsn):转换wal日志位置为文件名。

    pg_walfile_name_offset(lsn pg_lsn):返回转换后的wal日志文件名和偏移量。

    10.0之前版本:

    postgres=# select pg_current_xlog_location(),
         pg_xlogfile_name(pg_current_xlog_location()),
         pg_xlogfile_name_offset(pg_current_xlog_location());
         
     pg_current_xlog_location |  pg_xlogfile_name  |  pg_xlogfile_name_offset  
    --------------------------+--------------------------+-------------------------------------
     596/C4DA2000    | 0000000100000596000000C4 | (0000000100000596000000C4,14295040)

    注:

    pg_current_xlog_location():获得当前wal日志写入位置。

    pg_xlogfile_name():转换wal日志位置为文件名。

    pg_xlogfile_name_offset():返回转换后的wal日志文件名和偏移量。

    补充:postgresql lsn与wal file的对应关系

    系统环境:

    PostgreSQL 11.6

    查看当前的LSN和wal 名称

    postgres=# select pg_current_wal_lsn(),pg_walfile_name(pg_current_wal_lsn());
    pg_current_wal_lsn | pg_walfile_name
    --------------------±-------------------------
    4/D20001B0 | 0000000100000004000000D2

    对应关系

    LSN:4/D20001B0

    说明:LNS有三部分组成

    4:代表walfile的第二部分

    D2:代表walfile文件的最后两位

    0001B0:代表偏移量

    walfile:00000001 00000004 000000D2

    说明:由24个字符,三部分组成,每部分由8个字符组成,代表含义如下

    00000001:代表数据库运行的时间轴,如果恢复过数据库(主备切换)这个值会增大

    00000004:对LSN的第二部分对应

    000000D2:代表walfile文件的最后两位

    查看walfile文件的路径

    postgres=# select * from pg_ls_waldir() order by modification desc limit 5;
    name | size | modification
    --------------------------±---------±-----------------------
    0000000100000004000000D2 | 16777216 | 2020-05-30 12:01:57+08
    0000000100000004000000D1 | 16777216 | 2020-05-27 16:11:10+08
    0000000100000004000000D0 | 16777216 | 2020-05-24 23:18:25+08
    0000000100000004000000CF | 16777216 | 2020-05-14 14:17:16+08
    0000000100000004000000CE | 16777216 | 2020-05-09 14:24:25+08

    说明:pg的walfile大小默认是16MB,可以在初始化数据库时通过initdb --wal-segsize=SIZE方式来修改

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • postgresql 利用xlog进行热备操作
    • Postgresql中xlog生成和清理逻辑操作
    • Postgresql去重函数distinct的用法说明
    • postgresql 12版本搭建及主备部署操作
    • 开源数据库postgreSQL13在麒麟v10sp1源码安装过程详解
    • postgresql初始化之initdb的使用详解
    • postgresql 如何查看pg_wal目录下xlog文件总大小
    • PostgreSQL 实现定时job执行(pgAgent)
    上一篇:修改postgresql存储目录的操作方式
    下一篇:postgresql 如何查看pg_wal目录下xlog文件总大小
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    postgresql之使用lsn 获取 wal文件名的实例 postgresql,之,使用,lsn,获取,