The Kafka Java APIs

$ cd ~/tmp
$ git clone https://github.com/wildmakaka/kafka-java-connect
$ cd kafka-java-connect/


$ vi gradle/wrapper/gradle-wrapper.properties


distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.1-bin.zip


$ ./gradlew --version


------------------------------------------------------------
Gradle 7.3.1
------------------------------------------------------------

Build time:   2021-12-01 15:42:20 UTC
Revision:     2c62cec93e0b15a7d2cd68746f3348796d6d42bd

Kotlin:       1.5.31
Groovy:       3.0.9
Ant:          Apache Ant(TM) version 1.10.11 compiled on July 10 2021
JVM:          17.0.1 (Oracle Corporation 17.0.1+12-LTS-39)
OS:           Linux 5.11.0-27-generic amd64


$ ./gradlew run


$ vi ./build.gradle


dependencies {
  testImplementation 'junit:junit:4.12'
}

replace on:

dependencies {
  implementation 'org.apache.kafka:kafka-clients:2.2.1'
  testImplementation 'junit:junit:4.12'
}


$ vi src/main/java/com/linuxacademy/ccdak/kafkaJavaConnect/Main.java


package com.linuxacademy.ccdak.kafkaJavaConnect;

import org.apache.kafka.clients.producer.*
import java.util.Properties;

public class Main {

    public static void main(String[] args) {
       Properties props = new Properties();
        props.put("bootstrap.servers", "localhost:9092");
        props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
        props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");

        Producer<String, String> producer = new KafkaProducer<>(props);

        for (int i = 0; i < 100; i++) {
            producer.send(new ProducerRecord<String, String>("count-topic", "count", Integer.toString(i)));
        }
        producer.close();
    }
}


$ ./gradlew run

or

$ ./gradlew clean build


// Receive Messages
$ kafka-console-consumer.sh \
    --bootstrap-server localhost:9092 \
    --topic count-topic \
    --from-beginning


returns:

0
1
2
3
4
5
6
7
8
9
***