Настройки соединения
Options. Доступны следующие настройки:
| Параметр | Тип | По умолчанию | Описание |
|---|---|---|---|
Protocol | Protocol | Native | Транспортный протокол: Native (TCP) или HTTP. См. TCP и HTTP. |
Addr | []string | — | Срез адресов в формате host:port. О подключении к нескольким узлам см. Подключение к нескольким узлам. |
Auth | Auth | — | Учетные данные для аутентификации (Database, Username, Password). См. Аутентификация. |
TLS | *tls.Config | nil | Настройка TLS. Значение, отличное от nil, включает TLS. См. TLS. |
DialContext | func(ctx, addr) (net.Conn, error) | — | Пользовательская функция dial для управления установкой TCP-соединений. |
DialTimeout | time.Duration | 30s | Максимальное время ожидания при открытии нового соединения. |
MaxOpenConns | int | MaxIdleConns + 5 | Максимальное число одновременно открытых соединений. |
MaxIdleConns | int | 5 | Количество бездействующих соединений, сохраняемых в пуле. |
ConnMaxLifetime | time.Duration | 1h | Максимальное время жизни соединения в пуле. См. Пул соединений. |
ConnOpenStrategy | ConnOpenStrategy | ConnOpenInOrder | Стратегия выбора узла из Addr. См. Подключение к нескольким узлам. |
BlockBufferSize | uint8 | 2 | Количество блоков, декодируемых параллельно. Более высокие значения повышают пропускную способность за счет памяти. Можно переопределить для каждого запроса через контекст. |
Settings | Settings | — | Карта настроек ClickHouse, применяемых ко всем запросам. Отдельные запросы могут переопределять их через контекст. |
Compression | *Compression | nil | Сжатие на уровне блоков. См. Сжатие. |
ReadTimeout | time.Duration | — | Максимальное время ожидания чтения с сервера за один вызов. |
FreeBufOnConnRelease | bool | false | Если установлено true, буфер памяти соединения возвращается в пул после каждого запроса. Снижает использование памяти ценой небольшой дополнительной нагрузки на CPU. |
Logger | *slog.Logger | nil | Структурированный логгер (Go log/slog). См. Логирование. |
Debug | bool | false | Устарело. Используйте Logger. Включает устаревший отладочный вывод в stdout. |
Debugf | func(string, ...any) | — | Устарело. Используйте Logger. Пользовательская функция отладочного логирования. Требует Debug: true. |
GetJWT | GetJWTFunc | — | Функция обратного вызова, возвращающая JWT-токен для аутентификации в ClickHouse Cloud (только HTTPS). |
HttpHeaders | map[string]string | — | Дополнительные HTTP-заголовки, отправляемые с каждым запросом (только HTTP-транспорт). |
HttpUrlPath | string | — | Дополнительный путь URL, добавляемый к HTTP-запросам (только HTTP-транспорт). |
HttpMaxConnsPerHost | int | — | Переопределяет MaxConnsPerHost в базовом http.Transport (только HTTP-транспорт). |
TransportFunc | func(*http.Transport) (http.RoundTripper, error) | — | Пользовательская фабрика HTTP-транспорта. Транспорт по умолчанию передается для выборочного переопределения (только HTTP-транспорт). |
HTTPProxyURL | *url.URL | — | URL HTTP-прокси для всех запросов (только HTTP-транспорт). |
TLS
DSN/OpenDB/Open) используют пакет Go tls для установки защищённого соединения. Клиент понимает, что нужно использовать TLS, если структура Options содержит ненулевой указатель tls.Config.
TLS.Config обычно достаточно для подключения к защищённому native-порту (обычно 9440) на сервере ClickHouse. Если у сервера ClickHouse нет действительного сертификата (истёк срок действия, неверное имя хоста, сертификат не подписан общепризнанным корневым центром сертификации), для InsecureSkipVerify можно установить значение true, но делать это настоятельно не рекомендуется.
tls.Config. Это может включать указание конкретных наборов шифров, принудительное использование определённой версии TLS (например, 1.2 или 1.3), добавление внутренней цепочки CA‑сертификатов, добавление клиентского сертификата (и приватного ключа), если этого требует сервер ClickHouse, а также большинство других параметров для более специализированной конфигурации безопасности.
Аутентификация
Подключение к нескольким узлам
Addr.
ConnOpenInOrder(по умолчанию) - адреса используются по порядку. Последующие адреса задействуются только в случае сбоя при подключении к адресам, расположенным выше в списке. По сути, это стратегия переключения при отказе.ConnOpenRoundRobin- Нагрузка равномерно распределяется между адресами по стратегии round-robin.ConnOpenRandom- Узел случайным образом выбирается из списка адресов.
ConnOpenStrategy
Пул соединений
MaxOpenConns, а максимальный размер пула задается параметром MaxIdleConns. Для выполнения каждого запроса клиент получает соединение из пула, а затем возвращает его обратно для повторного использования. Соединение используется на протяжении всего жизненного цикла батча и освобождается при вызове Send().
Нет гарантии, что для последующих запросов из пула будет использоваться одно и то же соединение, если только пользователь не задаст MaxOpenConns=1. Это требуется редко, но может быть необходимо при использовании временных таблиц.
Также обратите внимание, что значение ConnMaxLifetime по умолчанию составляет 1 час. Это может приводить к неравномерному распределению нагрузки на ClickHouse, если узлы покидают кластер. Например, если узел становится недоступным, соединения перераспределяются на другие узлы. По умолчанию эти соединения сохраняются и не обновляются в течение 1 часа, даже если проблемный узел вернется в кластер. При высокой рабочей нагрузке стоит рассмотреть уменьшение этого значения.
Пул соединений поддерживается как для Native (TCP), так и для HTTP-протокола.
Логирование
log/slog, используя поле Logger в Options. Поля Debug и Debugf считаются устаревшими, но по-прежнему работают для обратной совместимости (приоритет: Debugf > Logger > no-op).
Сжатие
LZ4 и ZSTD. Оно выполняется только на уровне блоков. Сжатие можно включить, добавив конфигурацию Compression к соединению.
gzip, deflate и br. Подробнее см. в разделе Database/SQL API — Compression.
TCP vs HTTP
| TCP (собственный протокол) | HTTP | |
|---|---|---|
| Порт по умолчанию | 9000 (без шифрования), 9440 (TLS) | 8123 (без шифрования), 8443 (TLS) |
| Включение | По умолчанию — не указывайте Protocol | Protocol: clickhouse.HTTP или используйте DSN с http:// |
| Сжатие | lz4, zstd | lz4, zstd, gzip, deflate, br |
| Сеансы | Встроены (всегда активны) | Явно — передавайте session_id как параметр настройки |
| HTTP-заголовки | — | HttpHeaders, HttpUrlPath, HttpMaxConnsPerHost |
| Пользовательский транспорт | — | TransportFunc |
| JWT-аутентификация | — | GetJWT (HTTPS в ClickHouse Cloud) |
OpenTelemetry (WithSpan) | ✅ | Сервер это поддерживает, но клиент пока не отправляет заголовок traceparent |