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

来源:脚本之家  责任编辑:小易  

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 如何清理WAL日志PostgreSQL11修改wal-segsize的操作PostgreSQL流复制参数max_wal_senders的用法说明postgresql中wal_level的三个参数用法说明postgresql减少wal日志生成量的操作postgresql 如何查看pg_wal目录下xlog文件总大小

  • 本文相关:
  • 浅谈postgresql的客户端认证pg_hba.conf
  • postgresql的crud操作详解
  • 浅谈postgresql中大小写不敏感问题
  • postgresql数据库事务出现未知状态的处理方法
  • postgresql分页数据重复问题的深入理解
  • postgresql varchar字段regexp_replace正则替换操作
  • phppgadmin 常见错误和问题的解决办法
  • windows postgresql 9.1 安装详细步骤
  • postgresql 计算时间差的秒数、天数实例
  • postgresql数据库安装部署搭建主从节点的详细过程(业务库)
  • 如何遏制PostgreSQL WAL的疯狂增长
  • 如何遏制PostgreSQL WAL的疯狂增长
  • 什么情况会触发 WAL 日志归档
  • 如何遏制PostgreSQL WAL的疯狂增长
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页postgresql 如何清理wal日志postgresql11修改wal-segsize的操作postgresql流复制参数max_wal_senders的用法说明postgresql中wal_level的三个参数用法说明postgresql减少wal日志生成量的操作postgresql 如何查看pg_wal目录下xlog文件总大小浅谈postgresql的客户端认证pg_hba.confpostgresql的crud操作详解浅谈postgresql中大小写不敏感问题postgresql数据库事务出现未知状态的处理方法postgresql分页数据重复问题的深入理解postgresql varchar字段regexp_replace正则替换操作phppgadmin 常见错误和问题的解决办法windows postgresql 9.1 安装详细步骤postgresql 计算时间差的秒数、天数实例postgresql数据库安装部署搭建主从节点的详细过程(业务库)postgresql 角色与用户管理介绍windows下postgresql数据库的下载windows下postgresql安装图解15个postgresql数据库实用命令分postgresql中的oid和xid 说明postgresql alter语句常用操作小windows postgresql 安装图文教程postgresql 安装和简单使用postgresql 创建表分区postgresql新手入门教程postgresql 启动失败的解决方案关于postgresql错误日志与慢查询日志收集postgresql中时间转换和加减操作postgresql 查看数据库,索引,表,表空间postgresql 实现多表关联删除解决sqoop从postgresql拉数据,报错tcp/ippostgresql基础知识之sql操作符实践指南postgresql的generate_series()函数的用法postgresql数据库安装部署搭建主从节点的postgresql教程(十九):sql语言函数
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved