当前位置: 首页 > news >正文

外贸网站推做嵌入式开发的公司

外贸网站推,做嵌入式开发的公司,品牌广告语,软件开发工具的基础是SpringBoot 整合 Avro 与 Kafka 详解 在大数据处理和实时数据流场景中#xff0c;Apache Kafka 和 Apache Avro 是两个非常重要的工具。Kafka 作为一个分布式流处理平台#xff0c;能够高效地处理大量数据#xff0c;而 Avro 则是一个用于序列化数据的紧凑、快速的二进制数…SpringBoot 整合 Avro 与 Kafka 详解 在大数据处理和实时数据流场景中Apache Kafka 和 Apache Avro 是两个非常重要的工具。Kafka 作为一个分布式流处理平台能够高效地处理大量数据而 Avro 则是一个用于序列化数据的紧凑、快速的二进制数据格式。将这两者结合并通过 Spring Boot 进行整合可以构建出高效、可扩展的实时数据处理系统。 一、环境准备 在开始整合之前需要准备好以下环境 Java确保已经安装了 JDK推荐使用 JDK 8 或更高版本。Maven用于管理项目的依赖和构建过程。Spring Boot作为项目的框架推荐使用较新的版本如 Spring Boot 2.x。Kafka确保 Kafka 已经安装并运行可以使用 Docker 部署 Kafka 集群。AvroAvro 依赖 JSON 定义的架构来序列化数据。 二、项目结构 一个典型的 Spring Boot 项目结构可能如下 spring-boot-kafka-avro ├── src │ ├── main │ │ ├── java │ │ │ └── com │ │ │ └── example │ │ │ ├── SpringBootKafkaAvroApplication.java │ │ │ ├── config │ │ │ │ └── KafkaConfig.java │ │ │ ├── producer │ │ │ │ └── KafkaProducer.java │ │ │ ├── consumer │ │ │ │ └── KafkaConsumer.java │ │ │ └── model │ │ │ └── ElectronicsPackage.java (由 Avro 自动生成) │ │ ├── resources │ │ │ ├── application.properties │ │ │ └── avro │ │ │ └── electronicsPackage.avsc (Avro 架构文件) │ └── test │ └── java │ └── com │ └── example │ └── SpringBootKafkaAvroApplicationTests.java └── pom.xml三、添加依赖 在 pom.xml 文件中添加必要的依赖 dependencies!-- Spring Boot Starter --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter/artifactId/dependency!-- Spring Kafka --dependencygroupIdorg.springframework.kafka/groupIdartifactIdspring-kafka/artifactIdversion2.9.13/version !-- 根据需要选择合适的版本 --/dependency!-- Avro --dependencygroupIdorg.apache.avro/groupIdartifactIdavro/artifactIdversion1.11.0/version !-- 根据需要选择合适的版本 --/dependency!-- Avro Maven Plugin --plugingroupIdorg.apache.avro/groupIdartifactIdavro-maven-plugin/artifactIdversion${avro.version}/versionexecutionsexecutionphasegenerate-sources/phasegoalsgoalschema/goal/goalsconfigurationsourceDirectory${project.basedir}/src/main/resources/avro//sourceDirectoryoutputDirectory${project.build.directory}/generated/avro/outputDirectory/configuration/execution/executions/plugin /dependencies四、定义 Avro 架构 在 src/main/resources/avro/ 目录下创建一个 Avro 架构文件 electronicsPackage.avsc {namespace: com.example.model,type: record,name: ElectronicsPackage,fields: [{name: package_number, type: [string, null], default: null},{name: frs_site_code, type: [string, null], default: null},{name: frs_site_code_type, type: [string, null], default: null}] }这个架构文件定义了 ElectronicsPackage 类包括三个字段package_number、frs_site_code 和 frs_site_code_type。 五、生成 Avro 类 运行 Maven 构建过程Avro Maven 插件会根据 electronicsPackage.avsc 文件生成相应的 Java 类 ElectronicsPackage.java。 六、配置 Kafka 在 application.properties 文件中配置 Kafka 的相关属性 spring.kafka.bootstrap-serverslocalhost:9092 spring.kafka.consumer.group-idmy-group spring.kafka.consumer.auto-offset-resetearliest spring.kafka.producer.key-serializerorg.apache.kafka.common.serialization.StringSerializer spring.kafka.producer.value-serializercom.example.config.AvroSerializer spring.kafka.consumer.key-deserializerorg.apache.kafka.common.serialization.StringDeserializer spring.kafka.consumer.value-deserializercom.example.config.AvroDeserializer注意这里指定了自定义的 AvroSerializer 和 AvroDeserializer 类。 七、实现 Avro 序列化器和反序列化器 创建 AvroSerializer 和 AvroDeserializer 类用于 Avro 数据的序列化和反序列化。 // AvroSerializer.java package com.example.config;import org.apache.avro.generic.GenericData; import org.apache.avro.generic.GenericRecord; import org.apache.avro.io.DatumWriter; import org.apache.avro.io.Encoder; import org.apache.avro.io.EncoderFactory; import org.apache.avro.specific.SpecificDatumWriter; import org.apache.avro.specific.SpecificRecord; import org.apache.kafka.common.serialization.Serializer;import java.io.ByteArrayOutputStream; import java.io.IOException;public class AvroSerializerT extends SpecificRecord implements SerializerT {private final DatumWriterT writer;public AvroSerializer(ClassT type) {this.writer new SpecificDatumWriter(type);}Overridepublic byte[] serialize(String topic, T data) {if (data null) {return null;}ByteArrayOutputStream out new ByteArrayOutputStream();Encoder encoder EncoderFactory.get().binaryEncoder(out, null);try {writer.write(data, encoder);encoder.flush();out.close();} catch (IOException e) {throw new RuntimeException(e);}return out.toByteArray();}Overridepublic void configure(MapString, ? configs, boolean isKey) {// No-op}Overridepublic void close() {// No-op} }// AvroDeserializer.java package com.example.config;import org.apache.avro.generic.GenericData; import org.apache.avro.generic.GenericRecord; import org.apache.avro.io.DatumReader; import org.apache.avro.io.Decoder; import org.apache.avro.io.DecoderFactory; import org.apache.avro.specific.SpecificDatumReader; import org.apache.avro.specific.SpecificRecord; import org.apache.kafka.common.serialization.Deserializer;import java.io.ByteArrayInputStream; import java.io.IOException; import java.util.Map;public class AvroDeserializerT extends SpecificRecord implements DeserializerT {private final ClassT type;private final DatumReaderT reader;public AvroDeserializer(ClassT type) {this.type type;this.reader new SpecificDatumReader(type);}Overridepublic T deserialize(String topic, byte[] data) {if (data null) {return null;}ByteArrayInputStream in new ByteArrayInputStream(data);Decoder decoder DecoderFactory.get().binaryDecoder(in, null);try {return reader.read(null, decoder);} catch (IOException e) {throw new RuntimeException(e);}}Overridepublic void configure(MapString, ? configs, boolean isKey) {// No-op
http://www.hkea.cn/news/14569625/

相关文章:

  • 仿站WordPress开发网站建设公司
  • 做英文网站地图网页设计作品中比较常用的网页元素有哪些
  • 手机微网站怎么设计方案wordpress 屏蔽搜索
  • 4399谁做的网站网站安全建设目的
  • 网站建设注意哪些内容石家庄建站培训
  • 做网站 江门哪些网站做的不好
  • 青岛做网站皆赴青岛博坊网站建设
  • 怎么做导购网站什么 a wordpress
  • 手机商城网站建设做单页网站怎么选产品
  • 祝桥建设网站wordpress如何自建页面
  • 免费网站建设企业海南省旅游专业网站发展电子商务缺乏强大的专业产业资源做后盾
  • 2019做seo网站pageadmin建站系统破解版
  • 香河县建设局网站怎样增加网站的权重
  • 网站设置怎么删除网站在线咨询怎么做
  • 免费的制作手机网站平台东莞营销型网站建设找火速
  • 标准型网站构建网站建设预算申请如何写
  • 网站显示百度地图如何利用开源代码做网站
  • 微网站有什么用服务器租用收费标准
  • wordpress建站收录快wordpress 图片地址
  • 门户网站定义分类id wordpress
  • 网站开发 海淀wordpress圆角插件汉化
  • 建设本地端网站免费ui网站
  • 做网站哪个公司最好wordpress搜索文章内容
  • 深圳企业网站制作公司怎样电子商务很难就业吗
  • asp net网站开发语言的特点dw软件网站建设教程
  • 做a短视频网站网络优化师
  • 2017年网站建设公司青海网网站建设
  • 怎么让学生在网站上做问卷调查网站建设需要掌握什么知识
  • 怎样做网站怎要加服务器wordpress登陆后台
  • 做自己的网站如何赚钱的注册域名在哪里注册