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

 更新时间:2021年01月12日 14:40:46   作者:怠惰的小小白  
这篇文章主要介绍了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中的collations用法详解

    PostgreSQL中的collations用法详解

    这篇文章主要介绍了PostgreSQL中的collations用法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 如何为PostgreSQL的表自动添加分区

    如何为PostgreSQL的表自动添加分区

    这篇文章主要介绍了如何为PostgreSQL的表自动添加分区,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 安全高效的PostgreSQL数据库迁移解决方案

    安全高效的PostgreSQL数据库迁移解决方案

    PostgreSQL数据库是一款高度可扩展的开源数据库系统,支持复杂的查询、事务完整性和多种数据类型由于各种业务需求,企业常常需要将数据在不同的云平台或私有环境之间迁移,所以本文小编给大家介绍了安全高效的PostgreSQL数据库迁移解决方案,需要的朋友可以参考下
    2023-11-11
  • 在windows下手动初始化PostgreSQL数据库教程

    在windows下手动初始化PostgreSQL数据库教程

    在windows下手动初始化PG,是一件比较麻烦的事,下面我具体写一下过程,大家做一下参考。
    2014-09-09
  • Postgresql REGEXP开头的正则函数用法图文详解

    Postgresql REGEXP开头的正则函数用法图文详解

    正则表达式是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串,下面这篇文章主要给大家介绍了关于Postgresql REGEXP开头的正则函数用法的相关资料,需要的朋友可以参考下
    2024-02-02
  • pgpool复制和负载均衡操作

    pgpool复制和负载均衡操作

    这篇文章主要介绍了pgpool复制和负载均衡操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • Postgresql中LIKE和ILIKE操作符的用法详解

    Postgresql中LIKE和ILIKE操作符的用法详解

    这篇文章主要介绍了Postgresql中LIKE和ILIKE操作符的用法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 解决postgresql 数据库 update更新慢的原因

    解决postgresql 数据库 update更新慢的原因

    这篇文章主要介绍了解决postgresql 数据库 update更新慢的原因,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • Postgresql主从异步流复制方案的深入探究

    Postgresql主从异步流复制方案的深入探究

    这篇文章主要给大家介绍了关于Postgresql主从异步流复制方案的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Postgresql具有一起的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • PostgreSQL中date_trunc函数的语法及一些示例

    PostgreSQL中date_trunc函数的语法及一些示例

    这篇文章主要给大家介绍了关于PostgreSQL中date_trunc函数的语法及一些示例的相关资料,DATE_TRUNC函数是PostgreSQL数据库中用于截断日期部分的函数,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-04-04

最新评论