码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Spring Cloud Stream Kafka(3.2.2版本)使用


    问题

    正在尝试只用Spring Cloud Stream Kafka。

    步骤

    配置

    spring:
      cloud:
        function:
          definition: project2Building    
        stream:
          kafka:
            binder:
              brokers: xxxx:9002
              configuration:
               	enable.auto.commit: false
               	session.timeout.ms: 30000
               	max.poll.records: 30
               	allow.auto.create.topics: false
               	auto.offset.reset: earliest
                # 反序列化配置
                key.serializer: org.apache.kafka.common.serialization.StringDeserializer
                value.deserializer: org.apache.kafka.common.serialization.StringDeserializer
                # JAAS配置
                security.protocol: SASL_PLAINTEXT
                sasl.mechanism: PLAIN
                sasl.jaas.config: "org.apache.kafka.common.security.plain.PlainLoginModule required username=\"xxx\" password=\"xxx\";"
              autoCreateTopics: false
          bindings:
            # 自定义消费bean的方法名称
            project2Building-in-0:
              # 消费组
              group: xxxx
              # 主题
              destination: xxxx
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29

    消费方法

    package xxxxx.config;
    
    import lombok.extern.slf4j.Slf4j;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.kafka.support.Acknowledgment;
    import org.springframework.kafka.support.KafkaHeaders;
    import org.springframework.messaging.Message;
    
    import java.util.function.Consumer;
    
    
    /**
     * 与xxxx的kafka对接处理
     * @author zyl
     */
    @Slf4j
    @Configuration
    public class MainConfig {
    
        @Bean
        public Consumer<Message<String>> project2Building(){
            return msg ->{
                log.info(String.format("Kafka消息:%s",msg.getPayload()));
                // TODO 手动提交kafka
                Acknowledgment acknowledgment = msg.getHeaders().get(KafkaHeaders.ACKNOWLEDGMENT, Acknowledgment.class);
                if (acknowledgment != null) {
                    acknowledgment.acknowledge();
                }
            };
        }
    
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    总结

    我用的这个版本Spring Cloud Stream Kafka(3.2.2版本)相对于Spring Boot 的Kafka库有点重量级了。这就是Spring Cloud 基于Kafka的流处理框架。

    参考:

    • Spring Cloud Stream Kafka Binder Reference Guide
    • Kafka With Spring Cloud Streams Using Function-based Mode
    • Spring Cloud Stream - functional and reactive
  • 相关阅读:
    2022年中南大学夏令营面试经验
    关系数据库与文档数据库对比
    银发经济崭露头角:海外网红营销如何助力假发品牌增长
    不同版本Ubuntu安装Docker及Docker desktop
    粒子群优化算法(PSO)python实践
    分享一个基于JavaWeb的私人牙科诊所预约挂号就诊系统的设计与实现项目源码调试 lw 开题 ppt
    花生壳 搭建服务器
    14.10 Socket 套接字选择通信
    [游戏开发][Shader]ShaderToy通用模板转Unity-CG语言
    C# 背景与前景
  • 原文地址:https://blog.csdn.net/fxtxz2/article/details/133254933
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号