在继续之前,您应该了解基本的 PostgreSQL 系统架构。理解 PostgreSQL 的各个部分如何交互将使本章更加清晰。
在数据库行话中,PostgreSQL 使用客户端/服务器模型。一个 PostgreSQL 会话由以下协同工作的进程(程序)组成:
与典型的客户端/服务器应用程序一样,客户端和服务器可以位于不同的主机上。在这种情况下,它们通过 TCP/IP 网络连接进行通信。您应该记住这一点,因为在客户端计算机上可以访问的文件在数据库服务器计算机上可能无法访问(或者只能使用不同的文件名访问)。
PostgreSQL 服务器可以处理来自客户端的多个并发连接。为了实现这一点,它会为每个连接启动(“fork”)一个新的进程。从那时起,客户端和新的服务器进程无需原始 postgres
进程的干预即可通信。因此,主管服务器进程始终在运行,等待客户端连接,而客户端和相关的服务器进程则会不断地出现和消失。(当然,这一切对用户来说都是不可见的。这里只是为了完整起见而提到。)
如果您在文档中看到任何不正确、与您在使用特定功能时的经验不符或需要进一步说明的内容,请使用此表格报告文档问题。