在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
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方式来修改 以上为个人经验,希望能给大家一个参考,也希望大家多多支持极客世界。如有错误或未考虑完全的地方,望不吝赐教。 |
请发表评论