Kafka之序列化

本文介绍了Kafka中生产者如何使用序列化器将对象转换为字节数组进行网络传输,以及消费者如何使用反序列化器将接收到的字节数组还原为对象。Kafka内置了多种序列化器,包括String、ByteArray等,要求生产者和消费者的序列化器匹配。若标准序列化器无法满足需求,可以使用Avro、JSON等通用工具或自定义序列化器。
摘要由CSDN通过智能技术生成
生产者需要用序列化器(Serializer)把对象转换成字节数组才能通过网络发送给Kafka。而在对侧,消费者需要用反序列化器(Deserializer)把从 Kafka 中收到的字节数组转换成相应的对象。
  1. 通常我们的数据量是十分庞大的,为了性能,程序中的序列化器也使用了客户端自带的org.apache.kafka.common.serialization.StringSerializer,除了用于String类型的序列化器,还有ByteArray、ByteBuffer、Bytes、Double、Integer、Long这几种类型,它们都实现了org.apache.kafka.common.serialization.Serializer接口,kafka 对其进行了再包装,提高Kafka实际中的性能,
  2. 生产者使用的序列化器和消费者使用的反序列化器是需要一一对应的,如果生产者使用了某种序列化器,比如StringSerializer,而消费者使用了另一种序列化器,比如IntegerSerializer,那么是无法解析出想要的数据的,这个普通加密和解密是一样的道理。
  3. 如果 Kafka 客户端提供的几种序列化器都无法满足应用需求,则可以选择使用如 Avro、JSON、Thrift、ProtoBuf和Protostuff等通用的序列化工具来实现,或者使用自定义类型的序列化器来实现,这里做一个例子
/**
 * @author jiangzhiwen
 * @version 1.0
 * @date 2020/7/8 10:38 上午
 */

public class CompanySeralize implements Serializer<CompanySeralize.Company> {
   
    private String encoding = "UTF-8";
    @Override
    public void configure
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值