生产者需要用序列化器(Serializer)把对象转换成字节数组才能通过网络发送给Kafka。而在对侧,消费者需要用反序列化器(Deserializer)把从 Kafka 中收到的字节数组转换成相应的对象。
- 通常我们的数据量是十分庞大的,为了性能,程序中的序列化器也使用了客户端自带的org.apache.kafka.common.serialization.StringSerializer,除了用于String类型的序列化器,还有ByteArray、ByteBuffer、Bytes、Double、Integer、Long这几种类型,它们都实现了org.apache.kafka.common.serialization.Serializer接口,kafka 对其进行了再包装,提高Kafka实际中的性能,
- 生产者使用的序列化器和消费者使用的反序列化器是需要一一对应的,如果生产者使用了某种序列化器,比如StringSerializer,而消费者使用了另一种序列化器,比如IntegerSerializer,那么是无法解析出想要的数据的,这个普通加密和解密是一样的道理。
- 如果 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