Перейти к основному содержанию
Перейти к основному содержанию

Опциональное защищённое взаимодействие между ClickHouse и ZooKeeper

Not supported in ClickHouse Cloud
Примечание

Эта страница не относится к ClickHouse Cloud. Описанная здесь процедура выполняется автоматически в сервисах ClickHouse Cloud.

Необходимо указать ssl.keyStore.location, ssl.keyStore.password и ssl.trustStore.location, ssl.trustStore.password для взаимодействия с клиентом ClickHouse через SSL. Эти параметры доступны, начиная с версии Zookeeper 3.5.2.

Вы можете добавить zookeeper.crt в список доверенных сертификатов.

sudo cp zookeeper.crt /usr/local/share/ca-certificates/zookeeper.crt
sudo update-ca-certificates

Раздел client в файле config.xml будет выглядеть следующим образом:

<client>
    <certificateFile>/etc/clickhouse-server/client.crt</certificateFile>
    <privateKeyFile>/etc/clickhouse-server/client.key</privateKeyFile>
    <loadDefaultCAFile>true</loadDefaultCAFile>
    <cacheSessions>true</cacheSessions>
    <disableProtocols>sslv2,sslv3</disableProtocols>
    <preferServerCiphers>true</preferServerCiphers>
    <invalidCertificateHandler>
        <name>RejectCertificateHandler</name>
    </invalidCertificateHandler>
</client>

Добавьте Zookeeper в конфигурацию ClickHouse, указав кластер и макросы:

<clickhouse>
    <zookeeper>
        <node>
            <host>localhost</host>
            <port>2281</port>
            <secure>1</secure>
        </node>
    </zookeeper>
</clickhouse>

Запустите clickhouse-server. В логах вы увидите:

<Trace> ZooKeeper: инициализирован, хосты: secure://localhost:2281

Префикс secure:// указывает на то, что соединение защищено с помощью SSL.

Чтобы убедиться, что трафик шифруется, запустите tcpdump на защищённом порту:

tcpdump -i any dst port 2281 -nnXS

И выполните запрос в clickhouse-client:

SELECT * FROM system.zookeeper WHERE path = '/';

При незашифрованном соединении в выводе команды tcpdump вы увидите что-то вроде этого:

..../zookeeper/quota.

При защищённом соединении этого быть не должно.