2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2

1.2. 架构基础 #

在继续之前,您应该了解基本的 PostgreSQL 系统架构。理解 PostgreSQL 的各个部分如何交互将使本章更加清晰。

在数据库行话中,PostgreSQL 使用客户端/服务器模型。一个 PostgreSQL 会话由以下协同工作的进程(程序)组成:

  • 一个服务器进程,它管理数据库文件,接受来自客户端应用程序的数据库连接,并代表客户端执行数据库操作。数据库服务器程序称为 postgres

  • 用户想要执行数据库操作的客户端(前端)应用程序。客户端应用程序在性质上可以非常多样化:客户端可以是面向文本的工具,图形应用程序,访问数据库以显示网页的 Web 服务器,或者专门的数据库维护工具。一些客户端应用程序随 PostgreSQL 分发版一起提供;大多数由用户开发。

与典型的客户端/服务器应用程序一样,客户端和服务器可以位于不同的主机上。在这种情况下,它们通过 TCP/IP 网络连接进行通信。您应该记住这一点,因为在客户端计算机上可以访问的文件在数据库服务器计算机上可能无法访问(或者只能使用不同的文件名访问)。

PostgreSQL 服务器可以处理来自客户端的多个并发连接。为了实现这一点,它会为每个连接启动(fork)一个新的进程。从那时起,客户端和新的服务器进程无需原始 postgres 进程的干预即可通信。因此,主管服务器进程始终在运行,等待客户端连接,而客户端和相关的服务器进程则会不断地出现和消失。(当然,这一切对用户来说都是不可见的。这里只是为了完整起见而提到。)

提交更正

如果您在文档中看到任何不正确、与您在使用特定功能时的经验不符或需要进一步说明的内容,请使用此表格报告文档问题。