目次
1. プロデューサーがメッセージを同期的に送信する (API コードの例)
1.1、pom ファイルのインポートの依存関係
-
依存パッケージ
<dependency> <groupId>org.apache.kafka</groupId> <artifactId>kafka-clients</artifactId> <version>3.0.0</version> </dependency>
1.2. API コード
-
コード例
-
注: 非同期送信に基づいて get() メソッドを呼び出すだけです。
package com.xz.kafka.producer; import org.apache.kafka.clients.producer.KafkaProducer; import org.apache.kafka.clients.producer.ProducerConfig; import org.apache.kafka.clients.producer.ProducerRecord; import org.apache.kafka.common.serialization.StringSerializer; import java.util.Properties; import java.util.concurrent.ExecutionException; /** * @author: xz * @since: 2023/4/2 14:27 * @description: 生产者同步发送消息 */ public class CustomProducerSync { public static void main(String[] args) throws ExecutionException, InterruptedException { //1、创建 kafka 生产者的配置对象 Properties properties = new Properties(); //2、给 kafka 配置对象添加配置信息:bootstrap.servers properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,"192.168.136.27:9092,192.168.136.28:9092,192.168.136.29:9092"); //3、指定对应的key和value的序列化类型 key.serializer value.serializer properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName()); properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG,StringSerializer.class.getName()); //4、创建 kafka 生产者对象 KafkaProducer<String, String> kafkaProducer = new KafkaProducer<>(properties); //5、调用 send 方法,发送消息 //只需在异步发送的基础上,再调用一下 get()方法即可。 for (int i = 0; i < 5; i++) { kafkaProducer.send(new ProducerRecord<>("news","zhangsan"+i)).get(); } //6、关闭资源 kafkaProducer.close(); } }
1.3. Kafka クラスターサーバーで Kafka コンシューマーを開始する
-
Kafka クラスター内のサーバーで Kafka コンシューマーを開始する
[root@localhost kafka-3.0.0]# bin/kafka-console-consumer.sh --bootstrap-server 192.168.136.27:9092 --topic news
-
IDEA でコードを実行すると、コンソールは次のようになります。
-
Kafka コンシューマーを開始するサーバーでメッセージが受信されるかどうかを観察します。以下に示すように: