返回顶部
首页 > 资讯 > 精选 >kafka序列化器和拦截器怎么自定义使用
  • 864
分享到

kafka序列化器和拦截器怎么自定义使用

2023-07-05 18:07:53 864人浏览 独家记忆
摘要

本篇内容主要讲解“kafka序列化器和拦截器怎么自定义使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“kafka序列化器和拦截器怎么自定义使用”吧!介绍序列化器是和数据在网络中的传输有关,数据

本篇内容主要讲解“kafka序列化器和拦截器怎么自定义使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“kafka序列化器和拦截器怎么自定义使用”吧!

    介绍

    序列化器是和数据在网络中的传输有关,数据在网络中的传输为字节流,所以生产者在发送时需要将其序列化为字节流,消费者收到消息时,需要将字节流反序列化为我们能够识别的对象,我们不难看出,这就是rpc通信,kafka中实现了很多自定义协议,我们知道,在RPC通信中,只有生产者和消费者的协议一样,才能相互传输和解析数据,在使用Http时,我们就不用去关注协议本身,因为HTTP是tcp的上层建筑,它自己实现了一套协议,我们不用去关注,但是使用RPC,我们是面向TCP编程,所以自然得约定和实现自己的协议,而序列化就是这过程中很重要的一部分。

    拦截器是一个随处可见的词,基本上很多框架中都有拦截器机制,它的作用主要是对请求进行拦截,我们可以对请求进行过滤和处理,以达到业务目的,比如spring中有HandlerInterceptor拦截器,在kafka种也有拦截器,我们可以自定义拦截器,对消息进行拦截,比如某些异常消息我们不需要发送,那么就将其拦截下来。

    序列化器

    数据在网络中传输是以字节流的形式进行传输,在生产者端发送消息需要先进行序列化,消费者端进行反序列化,序列化的方式有很多,比如jdkJSON,protobuf,kryo,hessian,avro等等,在大数据量的传输中,序列化和反序列化的效率对吞吐量有一定的影响,kafka提供了许多序列化和反序列化器,如StringDeserializerStringSerializer,如果我们需要自定义一个序列化和反序列化器,那么实现Serializer,Deserializer接口即可。

    如下,kafka生产者在发送消息到broker之前需要序列化,消费者从broker获取消息后需要反序列化。

    kafka序列化器和拦截器怎么自定义使用

    设置序列化和反序列化

    生产者端设置序列化

    //序列化props.put("key.serializer", StringSerializer.class.getName());props.put("value.serializer", StringSerializer.class.getName());

    消费者端设置反序列化

    props.put("key.deserializer", StringDeserializer.class.getName());props.put("value.deserializer", StringDeserializer.class.getName());

    自定义序列化

    public class jsonSerializer<T> implements Serializer<T> {  @Override  public byte[] serialize(String topic, T obj) {    try {      return obj == null ? null : JSON.toJSONBytes(obj);    }catch (Exception e){      throw new SerializationException("json serializing exception");    }  }  }

    自定义反序列化

    public class  JsonDeserializer<T> implements Deserializer<T> {  @Override  public T deserialize(String topic, byte[] data) {    return (T) JSON.parse(data);  }}

    如上简单的使用fastjson作为序列化和反序列化工具,演示了自定义kafka的序列化和反序列化机制,我们可以根据实际情况来设计不同的序列化反序列化机制,当然,不会是像上面这些简单,如果使用spring,那么spring提供了JSON序列化和反序列化器直接使用。

    思考

    虽然我们可以自定义序列化和反序列化器,但是自定义序列化和反序列化器在使用上也要保持一些一致,也就是说生产者和消费者要保持使用一种类型的序列化机制,不然会出现消息转换问题,如果我们以kafka的方式向别人提供服务,那么他们就需要使用我们的制定的序列化方式,所以这可能就存在一定的耦合,如果使用Kafka的String序列化和反序列化机制,因为是它是默认方式并且是字符串,通用性比较好,所以就不用去考虑序列化和反序列化,直接拿到字符串转为对象,再进行业务处理,使用自定义序列化的话,就直接拿到序列化后的对象,不用进行字符串转对象操作。

    在实际场景中,我们可以根据自己的业务来使用何种序列化方式,没有最好的,只有合适的。

    拦截器

    kafka中消费者和生产者都有拦截器,分别为ConsumerInterceptorProducerInterceptor,只需实现它们即可实现拦截,加入拦截器后,生产者会在发送消息之前对消息进行拦截处理,消费者在收到消息之前也会经过拦截器,那么我们就可以在拦截器中加入一些自己需要的逻辑。

    如下消费者拦截器对消息进行拦截,如果有异常消息,则对异常消息进行处理,只要需要对消息进行处理,监控等,都可以使用拦截器。

    public class MyConsumerInterceptor implements ConsumerInterceptor<String, Message> {  @Override  public ConsumerRecords<String, Message> onConsume(ConsumerRecords<String, Message> records) {    long currentTimeMillis = System.currentTimeMillis();    records.forEach(record -> {      if ("消息异常".equals(record.value().getMessageText())) {        //处理异常消息        this.handleMsg(record);      }    });    return records;  }    private void handleMsg(ConsumerRecord<String, Message> record) {    //处理异常消息  }  @Override  public void onCommit(Map<TopicPartition, OffsetAndMetadata> offsets) {}  @Override  public void close() {}  @Override  public void configure(Map<String, ?> configs) { }}

    拦截器可以有多个,如果设置多个拦截器,那么就形成一个拦截器链,一个一个地执行。

    下面是使用spring-kafka时所配置的拦截器和序列化器的基本配置。

    spring:  kafka:    bootstrap-servers: 127.0.0.1:9092    consumer:      # 反序列化器      key-deserializer: org.springframework.kafka.support.serializer.JsonDeserializer      value-deserializer: org.springframework.kafka.support.serializer.JsonDeserializer      properties:        # 拦截器        interceptor:          classes: com.steakliu.kafka.interceptor.MyConsumerInterceptor        spring:          json:            trusted:              packages: '*'    producer:      key-serializer: org.springframework.kafka.support.serializer.JsonSerializer      value-serializer: org.springframework.kafka.support.serializer.JsonSerializer      properties:        # 拦截器        interceptor:          classes: com.steakliu.kafka.interceptor.MyProducerInterceptor,com.steakliu.kafka.interceptor.MyProducerInterceptor2

    到此,相信大家对“kafka序列化器和拦截器怎么自定义使用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    --结束END--

    本文标题: kafka序列化器和拦截器怎么自定义使用

    本文链接: https://lsjlt.com/news/354161.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • kafka序列化器和拦截器怎么自定义使用
      本篇内容主要讲解“kafka序列化器和拦截器怎么自定义使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“kafka序列化器和拦截器怎么自定义使用”吧!介绍序列化器是和数据在网络中的传输有关,数据...
      99+
      2023-07-05
    • struts2拦截器怎么自定义
      要自定义Struts2拦截器,您需要按照以下步骤进行操作:1. 创建一个实现 `com.opensymphony.xwork2.in...
      99+
      2023-08-26
      struts2
    • Spring中自定义拦截器怎么用
      小编给大家分享一下Spring中自定义拦截器怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!创建自定义拦截器类(UserTokenInterceptor)并实...
      99+
      2023-06-29
    • Spring中自定义拦截器的使用
      1、创建自定义拦截器类(UserTokenInterceptor)并实现HandlerInterceptor 接口,再重写方法,代码如下: public class UserToke...
      99+
      2024-04-02
    • 怎么自定义redis缓存拦截器
      自定义Redis缓存拦截器的步骤如下:1. 创建一个实现了`HandlerInterceptor`接口的自定义类,并重写其三个方法`...
      99+
      2023-09-11
      redis
    • springboot自定义拦截器简单使用及举例
      目录1. 自定义拦截器2. 拦截器登录验证的小demo2.1 配置pom.xml2.2 创建User的bean组件2.3 创建需要的表单页面以及登录成功的页面2.4 编写contro...
      99+
      2023-01-28
      springboot自定义拦截器 springboot拦截所有请求 springboot 拦截器
    • SpringBoot中怎么利用AOP和拦截器实现自定义注解
      本篇内容主要讲解“SpringBoot中怎么利用AOP和拦截器实现自定义注解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SpringBoot中怎么利用AOP和拦截器实现自定义注解”吧!Spri...
      99+
      2023-07-02
    • 拦截器在Spring MVC中怎么实现自定义
      拦截器在Spring MVC中怎么实现自定义?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1. 引言拦截器(Interceptor)实现对每一个请求处理前后进行...
      99+
      2023-05-31
      spring mvc
    • MyBatis中怎么实现自定义的SQL拦截器
      在 MyBatis 中实现自定义的 SQL 拦截器,通常可以通过实现 org.apache.ibatis.plugin.Interc...
      99+
      2024-05-08
      MyBatis SQL
    • C#序列化怎么自定义
      在C#中,可以通过实现ISerializable接口来自定义对象的序列化方式。ISerializable接口要求实现GetObjec...
      99+
      2024-03-01
      C#
    • Mybatis自定义拦截器和插件开发详解
      前言 在Spring中我们经常会使用到拦截器,在登录验证、日志记录、性能监控等场景中,通过使用拦截器允许我们在不改动业务代码的情况下,执行拦截器的方法来增强现有的逻辑。在mybati...
      99+
      2024-04-02
    • 使用SpringBoot如何实现自定义过滤器与拦截器
      使用SpringBoot如何实现定义过滤器与拦截器?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、自定义过滤器创建一个过滤器,实现javax.servlet.Filter...
      99+
      2023-05-31
      springboot 拦截器 监听器
    • springboot序列化和反序列化怎么定义
      在Spring Boot中,序列化和反序列化可以通过以下方式进行定义:1. 实现Serializable接口:在需要进行序列化和反序...
      99+
      2023-08-14
      springboot
    • SpringBoot中利用AOP和拦截器实现自定义注解
      目录前言Spring实现自定义注解1.引入相关依赖2.相关类Java实现自定义注解通过Cglib实现通过JDk动态代理实现Cglib和JDK动态代理的区别写在最后前言 最近遇到了这样...
      99+
      2024-04-02
    • Java拦截器以及自定义注解的使用是怎么样的
      Java拦截器以及自定义注解的使用是怎么样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1,设置预处理,设置不需要拦截的请求@Componentpublic cla...
      99+
      2023-06-22
    • 详解Java拦截器以及自定义注解的使用
      目录1,设置预处理,设置不需要拦截的请求2.UserTokenInterceptor ,securityInterceptor分别处理不同的请求拦截,执行不同的拦截逻辑。3.关于注解...
      99+
      2024-04-02
    • 详解SpringBoot中自定义和配置拦截器的方法
      目录1.SpringBoot版本2.什么是拦截器3.工作原理4.拦截器的工作流程4.1正常流程4.2中断流程5.应用场景6.如何自定义一个拦截器7.如何使其在Spring Boot中...
      99+
      2024-04-02
    • java自定义序列化的具体使用
      目录1.问题引出 2.解决办法 3.另外一种自定义序列化机制(介绍Externalizable) 1.问题引出 在某些情况下,我们可能不想对于一个对象的所有field进行序列化,例...
      99+
      2024-04-02
    • Java自定义过滤器和拦截器实现ThreadLocal线程封闭
      目录线程封闭ThreadLocal线程封闭实现步骤封装ThredLocal的方法自定义过滤器自定义拦截器Application类启动类中配置自定义过滤器和拦截器定义调用接口请求访问验...
      99+
      2022-11-13
      Java ThreadLocal线程封闭 Java 线程封闭
    • SpringMVC拦截器怎么使用
      今天小编给大家分享一下SpringMVC拦截器怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。SpringMVC 的拦...
      99+
      2023-07-05
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作