Kafka - 分布式发布订阅消息系统

在这里插入图片描述

Kafka是一个开源的分布式发布订阅消息系统,可以实现高吞吐量的消息处理。下面是一个使用Kafka的Java代码示例:

  1. 生产者代码:
import org.apache.kafka.clients.producer.*;

import java.util.Properties;

public class KafkaProducerExample {

    public static void main(String[] args) {

        // 设置Kafka生产者的配置
        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");

        // 创建Kafka生产者
        Producer<String, String> producer = new KafkaProducer<>(props);

        // 发送消息
        String topic = "my-topic";
        String key = "my-key";
        String value = "Hello, Kafka!";
        ProducerRecord<String, String> record = new ProducerRecord<>(topic, key, value);
        producer.send(record, new Callback() {
            @Override
            public void onCompletion(RecordMetadata metadata, Exception exception) {
                if (exception != null) {
                    System.out.println("Failed to send message: " + exception.getMessage());
                } else {
                    System.out.println("Message sent successfully. Offset: " + metadata.offset());
                }
            }
        });

        // 关闭生产者
        producer.close();
    }
}
  1. 消费者代码:
import org.apache.kafka.clients.consumer.*;

import java.util.Arrays;
import java.util.Properties;

public class KafkaConsumerExample {

    public static void main(String[] args) {

        // 设置Kafka消费者的配置
        Properties props = new Properties();
        props.put("bootstrap.servers", "localhost:9092");
        props.put("group.id", "my-group");
        props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
        props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

        // 创建Kafka消费者
        Consumer<String, String> consumer = new KafkaConsumer<>(props);

        // 订阅主题
        String topic = "my-topic";
        consumer.subscribe(Arrays.asList(topic));

        // 拉取和处理消息
        while (true) {
            ConsumerRecords<String, String> records = consumer.poll(100);
            for (ConsumerRecord<String, String> record : records) {
                System.out.println("Received message: key=" + record.key() + ", value=" + record.value() +
                        ", partition=" + record.partition() + ", offset=" + record.offset());
            }
        }

        // 关闭消费者
        consumer.close();
    }
}

生产者使用KafkaProducer类发送消息,消费者使用KafkaConsumer类订阅主题并拉取和处理消息。你需要将示例中的localhost:9092替换为你的Kafka集群的地址。另外,你还需要确保Kafka服务器已启动,并且创建了名为my-topic的主题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT_WEH_coder

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值