Composable Protocols
Overview
Composable protocols allow more flexible configuration of TCP access to the ClickHouse server. This configuration can co-exist alongside, or replace, conventional configuration.
Configuring composable protocols
Composable protocols can be configured in an XML configuration file. The protocols
section is denoted with protocols
tags in the XML config file:
Configuring protocol layers
You can define protocol layers using basic modules. For example, to define an
HTTP layer, you can add a new basic module to the protocols
section:
Modules can be configured according to:
plain_http
- name which can be referred to by another layertype
- denotes the protocol handler which will be instantiated to process data. It has the following set of predefined protocol handlers:tcp
- native clickhouse protocol handlerhttp
- HTTP clickhouse protocol handlertls
- TLS encryption layerproxy1
- PROXYv1 layermysql
- MySQL compatibility protocol handlerpostgres
- PostgreSQL compatibility protocol handlerprometheus
- Prometheus protocol handlerinterserver
- clickhouse interserver handler
gRPC
protocol handler is not implemented for Composable protocols
Configuring endpoints
Endpoints (listening ports) are denoted by <port>
and optional <host>
tags.
For example, to configure an endpoint on the previously added HTTP layer we
could modify our configuration as follows:
If the <host>
tag is omitted, then the <listen_host>
from the root config is
used.
Configuring layer sequences
Layers sequences are defined using the <impl>
tag, and referencing another
module. For example, to configure a TLS layer on top of our plain_http module
we could further modify our configuration as follows:
Attaching endpoints to layers
Endpoints can be attached to any layer. For example, we can define endpoints for HTTP (port 8123) and HTTPS (port 8443):
Defining additional endpoints
Additional endpoints can be defined by referencing any module and omitting the
<type>
tag. For example, we can define another_http
endpoint for the
plain_http
module as follows:
Specifying additional layer parameters
Some modules can contain additional layer parameters. For example, the TLS layer
allows a private key (privateKeyFile
) and certificate files (certificateFile
)
to be specified as follows: