2、Connecting to Kafka

KafkaAdmin-请参阅配置主题

ProducerFactory-请参阅发送消息

ConsumerFactory-请参阅接收消息

从2.5版本开始,每个版本都扩展了KafkaResourceFactory。这允许在运行时通过向引导服务器的配置中添加Supplier<String>来更改引导服务器:setBootstrapServersSupplier(()->...)。所有新连接都将调用此命令以获取服务器列表。消费者和生产者通常寿命较长。要关闭现有的生产者,请在DefaultKafkaProducerFactory上调用reset()。要关闭现有的Consumers,请在KafkaListenerEndpointRegistry上调用stop()(然后调用start())和/或在任何其他侦听器容器bean上调用stop()和start()。

为了方便起见,该框架还提供了一个支持两组引导服务器的ABSwitch集群;其中一个在任何时候都是活动的。通过调用setBootstrapServersSupplier()配置ABSwitchCluster并将其添加到生产者和消费者工厂以及KafkaAdmin。当你想切换时,在生产者工厂上调用primary()或secondary()并调用reset()来建立新的连接;对于消费者,stop()和start()都是监听器容器。使用@KafkaListeners时,停止()和启动()KafkaListenerEndpointRegistry bean。

有关更多信息,请参阅Javadocs。

Factory Listeners

从2.5版本开始,DefaultKafkaProducerFactory和DefaultKafkaConsumerFactory可以配置一个监听器,以便在创建或关闭生产者或消费者时接收通知。

java 复制代码
interface Listener<K, V> {

    default void producerAdded(String id, Producer<K, V> producer) {
    }

    default void producerRemoved(String id, Producer<K, V> producer) {
    }

}
java 复制代码
interface Listener<K, V> {

    default void consumerAdded(String id, Consumer<K, V> consumer) {
    }

    default void consumerRemoved(String id, Consumer<K, V> consumer) {
    }

}

在每种情况下,id都是通过将客户端id属性(在创建后从metrics()中获得)附加到工厂beanName属性中创建的,用..分隔。。

例如,这些监听器可用于在创建新客户端时创建和绑定Micrometer KafkaClientMetrics实例(并在客户端关闭时关闭它)。

该框架提供了正是这样做的监听器;请参见千分尺本地度量。

Default client ID prefixes

从版本3.2开始,对于使用Spring.application.name属性定义应用程序名称的Spring Boot应用程序,此名称现在用作这些客户端类型的自动生成客户端ID的默认前缀:

不使用消费者群体的消费者客户

生产商客户

管理员客户端

这使得在服务器端更容易识别这些客户端,以便进行故障排除或应用配额。

Client Type Without application name With application name

|----------------------------------------|--------------------|--------------------|
| consumer without consumer group | consumer-null-1 | myapp-consumer-1 |
| consumer with consumer group "mygroup" | consumer-mygroup-1 | consumer-mygroup-1 |
| producer | producer-1 | myapp-producer-1 |
| admin | adminclient-1 | myapp-admin-1 |

相关推荐
JaguarJack27 分钟前
OpenClaw 最新保姆级飞书对接指南教程 搭建属于你的 AI 助手
ai·clawdbot·openclaw
lucky670730 分钟前
Spring Boot集成Kafka:最佳实践与详细指南
spring boot·kafka·linq
Coder_Boy_38 分钟前
基于Spring AI的分布式在线考试系统-事件处理架构实现方案
人工智能·spring boot·分布式·spring
x-cmd1 小时前
[260207] x-cmd 更新 v0.8.0:Kimi、豆包、智谱全集结!薅到摩尔线程试用后,帮你秒接入 Claude code!
ai·x-cmd·kimi·zhipu·摩尔线程·doubao·claude-code
xuhe21 小时前
[全流程详细教程]Docker部署ClawBot, 使用GLM4.7, 接入TG Bot实现私人助理. 解决Docker Openclaw Permission Denied问题
linux·docker·ai·github·tldr
袁煦丞 cpolar内网穿透实验室2 小时前
远程调试内网 Kafka 不再求运维!cpolar 内网穿透实验室第 791 个成功挑战
运维·分布式·kafka·远程工作·内网穿透·cpolar
岁岁种桃花儿2 小时前
CentOS7 彻底卸载所有JDK/JRE + 重新安装JDK8(实操完整版,解决kafka/jps报错)
java·开发语言·kafka
人间打气筒(Ada)2 小时前
GlusterFS实现KVM高可用及热迁移
分布式·虚拟化·kvm·高可用·glusterfs·热迁移
xu_yule2 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式
AI架构师小马3 小时前
Hive调优手册:从入门到精通的完整指南
数据仓库·hive·hadoop·ai