Using Vector with Kafka and ClickHouse
Using Vector with Kafka and ClickHouse
Vector is a vendor-agnostic data pipeline with the ability to read from Kafka and send events to ClickHouse.
A getting started guide for Vector with ClickHouse focuses on the log use case and reading events from a file. We utilize the Github sample dataset with events held on a Kafka topic.
Vector utilizes sources for retrieving data through a push or pull model. Sinks meanwhile provide a destination for events. We, therefore, utilize the Kafka source and ClickHouse sink. Note that whilst Kafka is supported as a Sink, a ClickHouse source is not available. Vector is as a result not appropriate for users wishing to transfer data to Kafka from ClickHouse.
Vector also supports the transformation of data. This is beyond the scope of this guide. The user is referred to the Vector documentation should they need this on their dataset.
Note that the current implementation of the ClickHouse sink utilizes the HTTP interface. The ClickHouse sink does not support the use of a JSON schema at this time. Data must be published to Kafka in either plain JSON format or as Strings.
License
Vector is distributed under the MPL-2.0 License
Gather your connection details
To connect to ClickHouse with HTTP(S) you need this information:
- 
The HOST and PORT: typically, the port is 8443 when using TLS or 8123 when not using TLS. 
- 
The DATABASE NAME: out of the box, there is a database named default, use the name of the database that you want to connect to.
- 
The USERNAME and PASSWORD: out of the box, the username is default. Use the username appropriate for your use case.
The details for your ClickHouse Cloud service are available in the ClickHouse Cloud console. Select the service that you will connect to and click Connect:
Choose HTTPS, and the details are available in an example curl command.
If you are using self-managed ClickHouse, the connection details are set by your ClickHouse administrator.
Steps
- Create the Kafka githubtopic and insert the Github dataset.
This dataset consists of 200,000 rows focused on the ClickHouse/ClickHouse repository.
- Ensure the target table is created. Below we use the default database.
- Download and install Vector. Create a kafka.tomlconfiguration file and modify the values for your Kafka and ClickHouse instances.
A few important notes on this configuration and behavior of Vector:
- This example has been tested against Confluent Cloud. Therefore, the sasl.*andssl.enabledsecurity options may not be appropriate in self-managed cases.
- A protocol prefix is not required for the configuration parameter bootstrap_serverse.g.pkc-2396y.us-east-1.aws.confluent.cloud:9092
- The source parameter decoding.codec = "json"ensures the message is passed to the ClickHouse sink as a single JSON object. If handling messages as Strings and using the defaultbytesvalue, the contents of the message will be appended to a fieldmessage. In most cases this will require processing in ClickHouse as described in the Vector getting started guide.
- Vector adds a number of fields to the messages. In our example, we ignore these fields in the ClickHouse sink via the configuration parameter skip_unknown_fields = true. This ignores fields that are not part of the target table schema. Feel free to adjust your schema to ensure these meta fields such asoffsetare added.
- Notice how the sink references of the source of events via the parameter inputs.
- Note the behavior of the ClickHouse sink as described here. For optimal throughput, users may wish to tune the buffer.max_events,batch.timeout_secsandbatch.max_bytesparameters. Per ClickHouse recommendations a value of 1000 is should be considered a minimum for the number of events in any single batch. For uniform high throughput use cases, users may increase the parameterbuffer.max_events. More variable throughputs may require changes in the parameterbatch.timeout_secs
- The parameter auto_offset_reset = "smallest"forces the Kafka source to start from the start of the topic - thus ensuring we consume the messages published in step (1). Users may require different behavior. See here for further details.
- Start Vector
By default, a health check is required before insertions begin to ClickHouse. This ensures connectivity can be established and the schema read. Prepend VECTOR_LOG=debugto obtain further logging which can be helpful should you encounter issues.
- Confirm the insertion of the data.
| count | 
|---|
| 200000 |