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

Содержание

57.1. Обзор
57.1.1. Обзор обмена сообщениями
57.1.2. Обзор расширенного выполнения запросов
57.1.3. Форматы и коды форматов
57.1.4. Версии протокола
57.2. Поток сообщений
57.2.1. Запуск
57.2.2. Простое выполнение запросов
57.2.3. Расширенное выполнение запросов
57.2.4. Конвейеризация
57.2.5. Вызов функций
57.2.6. Операции COPY
57.2.7. Асинхронные операции
57.2.8. Отмена выполняющихся запросов
57.2.9. Завершение
57.2.10. Защита сеанса с SSL
57.2.11. Защита сеанса с GSSAPI
57.3. Аутентификация SASL
57.3.1. Аутентификация SCRAM-SHA-256
57.3.2. Аутентификация OAUTHBEARER
57.4. Протокол потоковой репликации
57.5. Протокол логической потоковой репликации
57.5.1. Параметры протокола логической потоковой репликации
57.5.2. Сообщения протокола логической репликации
57.5.3. Поток сообщений протокола логической репликации
57.6. Типы данных в сообщениях
57.7. Форматы сообщений
57.8. Поля сообщений с ошибками и замечаниями
57.9. Форматы сообщений логической репликации
57.10. Сводка изменений по сравнению с протоколом версии 2.0

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

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

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