ClickHouseとZookeeper間のオプションの安全な通信
Not supported in ClickHouse Cloud
ClickHouseクライアントとのSSL通信のために、ssl.keyStore.location
、ssl.keyStore.password
、ssl.trustStore.location
、ssl.trustStore.password
を指定する必要があります。これらのオプションはZookeeperバージョン3.5.2から利用可能です。
zookeeper.crt
を信頼された証明書に追加することができます。
sudo cp zookeeper.crt /usr/local/share/ca-certificates/zookeeper.crt
sudo update-ca-certificates
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>
クラスターとマクロを持つClickHouse設定にZookeeperを追加します:
<clickhouse>
<zookeeper>
<node>
<host>localhost</host>
<port>2281</port>
<secure>1</secure>
</node>
</zookeeper>
</clickhouse>
clickhouse-server
を開始します。ログには次のように表示されます:
<Trace> ZooKeeper: initialized, hosts: secure://localhost:2281
プレフィックスsecure://
は接続がSSLによって保護されていることを示します。
トラフィックが暗号化されていることを確認するためには、保護されたポートでtcpdump
を実行します:
tcpdump -i any dst port 2281 -nnXS
そして、clickhouse-client
でクエリを実行します:
SELECT * FROM system.zookeeper WHERE path = '/';
暗号化されていない接続では、tcpdump
の出力に次のようなものが表示されます:
暗号化された接続では、これを表示してはいけません。