【PG】PostgreSQL 目录结构

目录

[1 软件安装目录](#1 软件安装目录)

[2 数据文件目录](#2 数据文件目录)

base/:存储每个数据库的基本数据文件

global/:包含了全局性质的系统表空间文件

pg_tblspc/:包含了表空间的符号链接

pg_twophase/:包含了两阶段提交中使用的文件

pg_stat_tmp/:包含了一些临时文件,用于存储统计信息

[pg_stat/:包含了 PostgreSQL 收集的统计信息文件](#pg_stat/:包含了 PostgreSQL 收集的统计信息文件)

pg_logical/:包含了用于逻辑复制的文件

pg_replslot/:包含了复制插槽信息的文件

pg_subtrans/:包含了用于存储子事务信息的文件

pg_notify/:包含了用于存储异步通知信息的文件。

pg_snapshots/:包含了用于存储快照信息的文件。

pg_serial/:包含了用于存储序列信息的文件


1 软件安装目录

/usr/local/pgsql目录下,通常会找到与PostgreSQL相关的子目录和文件。以下是一些常见的组件:

  • /bin: 该目录通常包含PostgreSQL的可执行文件,如psql(PostgreSQL命令行客户端)和其他实用程序。

  • /data: 这是PostgreSQL存储其数据文件的常见目录,包括主数据库集群。数据目录在PostgreSQL安装过程中指定,并包含诸如base等子目录,其中存储实际的表数据。

  • /lib: 该目录通常包含PostgreSQL所需的共享库。

  • /share: 该目录可能包含PostgreSQL使用的与架构无关的文件,例如错误消息、时区信息和其他共享资源。

  • /doc: PostgreSQL的文档文件可能存放在这里。

  • /include: 编译与PostgreSQL交互的程序所需的头文件。

值得注意的是,安装目录的确切结构可能会根据安装方法和操作系统而有所不同。请始终参考您正在使用的特定版本PostgreSQL的文档或安装说明,以获取准确的详细信息。

2 数据文件目录

PostgreSQL 的 data_directory 是一个包含着数据库集群所有数据文件和相关信息的目录。这个目录下的文件和子目录有着不同的用途,以下是其中一些重要的文件和子目录的解释:

base/: 存储每个数据库的基本数据文件

存储每个数据库的基本数据文件。每个数据库都有一个以其 OID(对象标识符)命名的子目录,里面包含了该数据库的所有表和索引的数据文件。
2.

global/: 包含了全局性质的系统表空间文件

包含了全局性质的系统表空间文件。这里存放了所有数据库共享的系统表,如 pg_databasepg_authid 等。
3.

**pg_tblspc/:**包含了表空间的符号链接

包含了表空间的符号链接。每个符号链接指向实际的表空间目录,表空间是用于组织数据库物理存储的一种方式。
4.

pg_twophase/: 包含了两阶段提交中使用的文件

包含了两阶段提交中使用的文件。两阶段提交用于确保分布式事务的一致性。
5.

**pg_stat_tmp/:**包含了一些临时文件,用于存储统计信息

pg_stat/: 包含了 PostgreSQL 收集的统计信息文件

包含了 PostgreSQL 收集的统计信息文件。这些文件记录了数据库服务器运行时的性能统计信息,如查询计划、锁等。
7.

pg_logical/: 包含了用于逻辑复制的文件

包含了用于逻辑复制的文件。逻辑复制允许将特定表、特定数据库对象或特定的数据更改复制到另一个数据库。
8.

**pg_replslot/:**包含了复制插槽信息的文件

包含了复制插槽信息的文件。复制插槽用于流复制中,确保备用节点能够持续接收主节点的 WAL(Write-Ahead Logging)。
9.

**pg_subtrans/:**包含了用于存储子事务信息的文件

包含了用于存储子事务信息的文件。子事务用于处理并发事务中的多个子操作。
10.

复制代码
#### **pg_notify/:**包含了用于存储异步通知信息的文件。

包含了用于存储异步通知信息的文件。异步通知允许数据库中的一个会话通知其他会话有关特定事件的发生。
复制代码
#### **pg_snapshots/:**包含了用于存储快照信息的文件。

包含了用于存储快照信息的文件。快照是一种数据库的一致性视图,用于支持可重复读事务隔离级别。
复制代码
#### **pg_serial/:**​​​​​​​包含了用于存储序列信息的文件

包含了用于存储序列信息的文件。序列是 PostgreSQL 中生成唯一标识符的一种方式。

除了上述目录,还有一些重要的配置文件:

  • postgresql.conf: 存放着 PostgreSQL 服务器的配置参数,如端口号、日志设置等。

  • pg_hba.conf: 存放着 PostgreSQL 的身份验证规则,定义了哪些主机和用户能够连接到数据库,以及使用哪种身份验证方法。

  • **pg_ident.conf:**存放着标识映射规则,用于将操作系统用户映射到 PostgreSQL 数据库用户。

相关推荐
努力学习的小廉1 分钟前
初识MYSQL —— 数据类型
android·数据库·mysql
MoRanzhi12037 分钟前
12. Pandas 数据合并与拼接(concat 与 merge)
数据库·人工智能·python·数学建模·矩阵·数据分析·pandas
William_cl15 分钟前
【连载3】MySQL 的 MVCC 机制剖析
数据库·mysql
2351619 分钟前
【MySQL】MVCC:从核心原理到幻读解决方案
java·数据库·后端·sql·mysql·缓存
zym大哥大23 分钟前
高并发内存池
服务器·数据库·windows
. . . . .42 分钟前
数据库迁移migration
数据库
shixian10304111 小时前
Django 学习日志
数据库·学习·sqlite
IT 小阿姨(数据库)2 小时前
PostgreSQL通过pg_basebackup物理备份搭建流复制备库(Streaming Replication Standby)
运维·服务器·数据库·sql·postgresql·centos
小蒜学长3 小时前
springboot基于javaweb的小零食销售系统的设计与实现(代码+数据库+LW)
java·开发语言·数据库·spring boot·后端
云边有个稻草人3 小时前
从内核调优到集群部署:基于Linux环境下KingbaseES数据库安装指南
linux·数据库·金仓数据库管理系统