返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

章44. 前/后端协议

发布于 2019-09-30 03:13:25 字数 974 浏览 990 评论 0 收藏 0

目录
44.1. 概述
44.1.1. 消息概貌
44.1.2. 扩展查询概述
44.1.3. 格式和格式代码
44.2. 消息流
44.2.1. 启动
44.2.2. 简单查询
44.2.3. 扩展查询
44.2.4. 函数调用
44.2.5. COPY 操作
44.2.6. 异步操作
44.2.7. 取消正在处理的请求
44.2.8. 终止
44.2.9. SSL 会话加密
44.3. 消息数据类型
44.4. 消息格式
44.5. 错误和通知消息字段
44.6. 自协议 2.0 以来的变化的概述

PostgreSQL 使用一种基于消息的协议用于前端和后端(服务器和客户机)之间通讯。该协议是在 TCP/IP 和 Unix 域套接字上实现的。端口号 5432 已经在 IANA 注册为使用这种协议的常用端口,但实际上任何非特权端口号都可以使用。

这份文档描述了版本 3.0 的协议,在 PostgreSQL 7.4 和以后的版本中实现。对于以前的协议的描述,请参考以前版本的 PostgreSQL 文档。一个服务器可以支持多种协议版本。初始化的启动信息告诉服务器客户端可以接受的协议版本,然后服务器则遵守该版本的协议(如果它能做到的话)。

在这个协议的基础上建立的更高级特性(例如 libpq 是如何在建立连接以后传递某种环境变量的)在其它地方描述。

为了可以有效地为多个客户端提供服务,服务器为每个客户端派生一个新的"后端"进程。在目前的实现里,在检测到到来的连接请求后,马上创建一个新的子进程。不过,这些是对协议透明的。对于协议而言,术语"后端"和"服务器"是可以互换的;类似的还有"前端"和"客户机"也是可以互换的。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文