Creating a Kafka Client
Kafka client is an application that lets you interact with a Kafka cluster. You create producer applications to send data to Kafka topics and consumer applications to read the messages from Kafka topics.
Before You Begin
- Confirm you created a Kafka cluster in OCI Streaming with Apache Kafka.
- Create a Compute instance in the OCI tenancy.
- Confirm that you can connect to the compute instance.
Installing Kafka
On each compute instance you create, you install the Apache Kafka client libraries and tools.
Configuring the Client
On each compute instance you create, you configure the client properties file.
Using the Kafka CLI
After installing and configuring the client application, use the built-in Apache Kafka CLI tools to manage and interact with the Kafka cluster in Streaming with Apache Kafka.
Apache Kafka includes some built-in clients. For example, the Java Consumer and Java Producer clients.
In addition, the Kafka community provides many more clients that you can use.
Following are some useful quick-references:
- Apache Kafka quickstart
- Adding and removing topics
- Updating topics
Managing Client Configuration
Kafka clients require specific configurations to specify how the client should send and receive messages, handle errors, and manage its connection to the Kafka cluster.
Apache Kafka provides command-line interface (CLI) tools in the /bin directory. For example, the kafka-configs.sh tool available in the installed Kafka client libraries can be used to manage client configurations. 
Following are some example of common CLI commands. Get cluster details for the bootstrap URL in the commands. Specify the path to the client.properties file you created when you configured the client.
To view a topic configuration, run the kafka-configs.sh tool by specifying the name of the topic for which you want to view the configuration. 
bin/kafka-configs.sh
--bootstrap-server $URL
--command-config /path/to/client.properties
--entity-type topics
--entity-name $TOPIC_NAME
                        --describe
                    To view partition and replication information for all topics, run the kafka-configs.sh tool. 
bin/kafka-configs.sh
--bootstrap-server $URL
--command-config /path/to/client.properties
                        --describe | grep Factor | sort 
                    To change a topic configuration, such as retention and segment, run the kafka-configs.sh tool by specifying the name of the topic for which you want to change the configuration.
bin/kafka-configs.sh
--bootstrap-server $URL
--command-config /path/to/client.properties
--entity-type topics
--entity-name $TOPIC_NAME
                        --alter
--add-config retention.ms=1, segment.ms=60000
                    To remove a topic configuration, such as retention and segment, run the kafka-configs.sh tool by specifying the name of the topic for which you want to remove the configuration.
bin/kafka-configs.sh
--bootstrap-server $URL
--command-config /path/to/client.properties
--entity-type topics
--entity-name $TOPIC_NAME
                        --alter
--delete-config retention.ms,segment.ms
                    To view disk usage for each partition, run the kafka-log-dirs.sh tool and specify the path to the output log file. 
bin/kafka-log-dirs.sh
--bootstrap-server $URL
--command-config /path/to/client.properties
                        --describe | tail -1 > /tmp/logdirs.output.txt
                        
                    Then, run the following command to filter the log file and display its contents. Adjust brokers[0] to target a specific broker.
cat /tmp/logdirs.output.txt
  | jq -r '.brokers[0] | .logDirs[0].partitions[] | .partition + " " + (.size|tostring)' 
  | sort 
  | awk 'BEGIN {sum=0} {sum+=$2} END {print sum}'To enable trace log for a broker, create a file log4j.properties with the following properties.
log4j.rootLogger=TRACE, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n Then, run the following command.
export KAFKA_OPTS="-Dlog4j.configuration=file:/path/to/log4j.properties"Monitoring Client Metrics
You must monitor the client applications and the Kafka cluster.
Use OCI Monitoring service to monitor the metrics emitted by the Kafka brokers.
For the client side metrics, you must create your own custom dashboard to monitor client applications. At a minimum, monitor the following client metrics:
- 
record-send-rate
- 
request-latency-avg
- 
error-rate
- 
records-consumed-rate
- 
lag
- 
fetch-latency-avg
- 
Retries
- 
disconnects