Эта страница не применима к ClickHouse Cloud. Описанная здесь возможность недоступна в сервисах ClickHouse Cloud.
Дополнительные сведения см. в руководстве ClickHouse Cloud Compatibility.
Аутентификация пользователей по SSL поддерживается при использовании интерфейсов
https, native, mysql и postgresql.Для безопасной аутентификации на узлах ClickHouse должен быть задан параметр <verificationMode>strict</verificationMode> (хотя для тестирования подойдет и relaxed).Если вы используете AWS NLB с интерфейсом MySQL, обратитесь в поддержку AWS, чтобы включить следующую недокументированную опцию:
Я хочу иметь возможность настроить proxy protocol v2 для NLB следующим образом: proxy_protocol_v2.client_to_server.header_placement,Value=on_first_ack.
1. Создайте SSL-сертификаты пользователя
В этом примере используются самоподписанные сертификаты с самоподписанным CA. Для рабочей среды создайте CSR и отправьте его вашей команде PKI или поставщику сертификатов, чтобы получить корректный сертификат.
- Сгенерируйте запрос на подпись сертификата (CSR) и ключ. Базовый формат выглядит следующим образом:
В этом примере мы используем следующие домен и пользователя для этой тестовой среды:
Значение CN произвольно, и в качестве идентификатора сертификата можно использовать любую строку. Оно используется при создании пользователя на следующих шагах.
- Сгенерируйте и подпишите новый сертификат пользователя, который будет использоваться для аутентификации. Базовый формат выглядит следующим образом:
В этом примере мы используем следующие домен и пользователя для этой тестовой среды:
2. Создайте SQL-пользователя и предоставьте права
Подробные сведения о том, как включить SQL-пользователей и назначать роли, см. в руководстве Определение SQL-пользователей и ролей.
-
Создайте SQL-пользователя с аутентификацией по сертификату:
-
Предоставьте привилегии новому пользователю с сертификатом:
В этом примере пользователю предоставлены полные административные привилегии в демонстрационных целях. Сведения о настройке прав см. в документации ClickHouse по RBAC.
Мы рекомендуем использовать SQL для определения пользователей и ролей. Однако если сейчас вы определяете пользователей и роли в конфигурационных файлах, пользователь будет выглядеть так:
3. Проверка
- Скопируйте сертификат пользователя, ключ пользователя и CA‑сертификат на удалённый узел.
-
Настройте OpenSSL в конфигурации клиента ClickHouse, указав сертификат и пути к файлам.
-
Запустите
clickhouse-client.
Обратите внимание: пароль, переданный в
clickhouse-client, игнорируется, если в конфигурации указан сертификат.4. Тестирование HTTP
- Скопируйте сертификат пользователя, его ключ и CA‑сертификат на удалённый узел.
-
С помощью
curlпротестируйте пример SQL-команды. Базовый формат:Например:Вывод будет примерно таким:
Обратите внимание: пароль не указывается, так как вместо него используется сертификат — именно по нему ClickHouse аутентифицирует пользователя.
Итоги
clickhouse-client или любыми клиентами, которые поддерживают интерфейс https и позволяют задавать HTTP-заголовки. Сгенерированные сертификат и ключ следует хранить в тайне и ограничить к ним доступ, поскольку сертификат используется для аутентификации и авторизации пользователя при выполнении операций в базе данных ClickHouse. Обращайтесь с сертификатом и ключом так же, как с паролями.