Глава 54. Клиент-серверный протокол

Содержание

54.1. Обзор
54.1.1. Обзор обмена сообщениями
54.1.2. Обзор расширенного выполнения запросов
54.1.3. Форматы и коды форматов
54.1.4. Версии протокола
54.2. Поток сообщений
54.2.1. Запуск
54.2.2. Простое выполнение запросов
54.2.3. Расширенное выполнение запросов
54.2.4. Конвейеризация
54.2.5. Вызов функций
54.2.6. Операции COPY
54.2.7. Асинхронные операции
54.2.8. Отмена выполняющихся запросов
54.2.9. Завершение
54.2.10. Защита сеанса с SSL
54.2.11. Защита сеанса с GSSAPI
54.3. Аутентификация SASL
54.3.1. Аутентификация SCRAM-SHA-256
54.3.2. Аутентификация OAUTHBEARER
54.4. Протокол потоковой репликации
54.5. Протокол логической потоковой репликации
54.5.1. Параметры протокола логической потоковой репликации
54.5.2. Сообщения протокола логической репликации
54.5.3. Поток сообщений протокола логической репликации
54.6. Типы данных в сообщениях
54.7. Форматы сообщений
54.8. Поля сообщений с ошибками и замечаниями
54.9. Форматы сообщений логической репликации
54.10. Сводка изменений по сравнению с протоколом версии 2.0

Клиенты и серверы PostgreSQL взаимодействуют друг с другом, используя специальный протокол, основанный на сообщениях. Этот протокол поддерживается для соединений по TCP/IP и через Unix-сокеты. Для серверов, поддерживающих этот протокол, в IANA зарезервирован номер TCP-порта 5432, но на практике можно задействовать любой порт, не требующий особых привилегий.

В этой документации описана версия 3.2 этого протокола, которая введена в PostgreSQL версии 18. Сервер и клиентская библиотека libpq обратно совместимы с версией 3.0 этого протокола, реализованной в PostgreSQL версии 7.4 и выше.

Чтобы эффективно обслуживать множество клиентов, сервер запускает отдельный «обслуживающий» процесс для каждого клиента. В текущей реализации новый дочерний процесс запускается немедленно после обнаружения входящего подключения. Однако это происходит прозрачно для протокола. С точки зрения протокола, термины «обслуживающий процесс», «процесс заднего плана» и «сервер» взаимозаменяемы, как и «приложение переднего плана» и «клиент».