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

Содержание

55.1. Обзор
55.1.1. Обзор обмена сообщениями
55.1.2. Обзор расширенного выполнения запросов
55.1.3. Форматы и коды форматов
55.1.4. Версии протокола
55.2. Поток сообщений
55.2.1. Запуск
55.2.2. Простое выполнение запросов
55.2.3. Расширенное выполнение запросов
55.2.4. Конвейеризация
55.2.5. Вызов функций
55.2.6. Операции COPY
55.2.7. Асинхронные операции
55.2.8. Отмена выполняющихся запросов
55.2.9. Завершение
55.2.10. Защита сеанса с SSL
55.2.11. Защита сеанса с GSSAPI
55.3. Аутентификация SASL
55.3.1. Аутентификация SCRAM-SHA-256
55.3.2. Аутентификация OAUTHBEARER
55.4. Протокол потоковой репликации
55.5. Протокол логической потоковой репликации
55.5.1. Параметры протокола логической потоковой репликации
55.5.2. Сообщения протокола логической репликации
55.5.3. Поток сообщений протокола логической репликации
55.6. Типы данных в сообщениях
55.7. Форматы сообщений
55.8. Поля сообщений с ошибками и замечаниями
55.9. Форматы сообщений логической репликации
55.10. Сводка изменений по сравнению с протоколом версии 2.0

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

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

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