pg_filedump

用于显示 PostgreSQL 堆、索引或控制文件格式化内容的实用程序

pg_filedump 是一个用于显示 PostgreSQL 堆、索引或控制文件格式化内容的实用程序。

pg_filedump 可用于从 PostgreSQL 9.0 开始的所有 PostgreSQL 版本。请注意,虽然它由 PostgreSQL 项目提供,但它不是核心实用程序,需要单独编译或安装。

发行历史

示例

创建一个包含一些任意数据的表

CREATE TABLE foo (id INT, val TEXT);
INSERT INTO foo VALUES(generate_series(1,5), md5(clock_timestamp()::TEXT));

CHECKPOINT; -- ensure contents are written from shared_buffers to disk

确定表的数**据文件的存储位置(有关此方面的更多信息,请参见 filenode

SELECT pg_relation_filepath('foo'::regclass);

使用以下命令以人类可读的格式转储内容-D选项(注意:为此,您需要了解列类型和顺序)

postgres $ pg_filedump -D int,text ./base/16385/32784

*******************************************************************
* PostgreSQL File/Block Formatted Dump Utility - Version 11.0
*
* File: ./base/16385/32784
* Options used: -D int,text
*
* Dump created on: Fri Dec  7 18:47:46 2018
*******************************************************************

Block    0 ********************************************************
<Header> -----
 Block Offset: 0x00000000         Offsets: Lower      44 (0x002c)
 Block: Size 8192  Version    4            Upper    7872 (0x1ec0)
 LSN:  logid      0 recoff 0x018dacb0      Special  8192 (0x2000)
 Items:    5                      Free Space: 7828
 Checksum: 0xd874  Prune XID: 0x00000000  Flags: 0x0000 ()
 Length (including item array): 44

<Data> ------
 Item   1 -- Length:   61  Offset: 8128 (0x1fc0)  Flags: NORMAL
COPY: 1	eb4f2363f1f90f13c31d18ec9ecb683e
 Item   2 -- Length:   61  Offset: 8064 (0x1f80)  Flags: NORMAL
COPY: 2	1cdce4984a6002b1ae1bafffc1eb31db
 Item   3 -- Length:   61  Offset: 8000 (0x1f40)  Flags: NORMAL
COPY: 3	8764bdccfbd32aaf0ae3ffb077f48d56
 Item   4 -- Length:   61  Offset: 7936 (0x1f00)  Flags: NORMAL
COPY: 4	fb37467829dc3f7a4124d6ea1f0fb77b
 Item   5 -- Length:   61  Offset: 7872 (0x1ec0)  Flags: NORMAL
COPY: 5	7398f49dc8c7027f73d75a6081b415bc


*** End of File Encountered. Last Block Read: 0 ***

分类

数据一致性和取证PostgreSQL 内部存储实用程序

参见

pageinspect,pg_hexdump

反馈

提交任何关于“pg_filedump”的评论、建议或更正 此处