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

青峰网站建设软媒win7优化大师

青峰网站建设,软媒win7优化大师,网站建设需求分析报告撰写,wordpress底部友情链接springboot 连接 kafka集群 一、环境搭建1.1 springboot 环境1.2 kafka 依赖 二、 kafka 配置类2.1 发布者2.1.1 配置2.1.2 构建发布者类2.1.3 发布消息 2.2 消费者2.2.1 配置2.2.2 构建消费者类2.2.3 进行消息消费 一、环境搭建 1.1 springboot 环境 JDK 11 Maven 3.8.x spr… springboot 连接 kafka集群 一、环境搭建1.1 springboot 环境1.2 kafka 依赖 二、 kafka 配置类2.1 发布者2.1.1 配置2.1.2 构建发布者类2.1.3 发布消息 2.2 消费者2.2.1 配置2.2.2 构建消费者类2.2.3 进行消息消费 一、环境搭建 1.1 springboot 环境 JDK 11 Maven 3.8.x springboot 2.5.4 1.2 kafka 依赖 springboot的pom文件导入 dependencygroupIdorg.springframework.kafka/groupIdartifactIdspring-kafka/artifactId/dependencydependencygroupIdorg.springframework.kafka/groupIdartifactIdspring-kafka-test/artifactIdscopetest/scope/dependencydependencygroupIdorg.apache.kafka/groupIdartifactIdkafka-clients/artifactIdversion3.4.0/version/dependency二、 kafka 配置类 2.1 发布者 2.1.1 配置 发布者我们使用 KafkaTemplate 来进行消息发布所以需要先对其进行一些必要的配置。 Configuration EnableKafka public class KafkaConfig {/***** 发布者 *****///生产者工厂Beanpublic ProducerFactoryInteger, String producerFactory() {return new DefaultKafkaProducerFactory(producerConfigs());}//生产者配置Beanpublic MapString, Object producerConfigs() {MapString, Object props new HashMap();props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, 192.168.2.83:9092,192.168.2.84:9092,192.168.2.86:9092);props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, IntegerSerializer.class);props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);return props;}//生产者模板Beanpublic KafkaTemplateInteger, String kafkaTemplate() {return new KafkaTemplate(producerFactory());} }2.1.2 构建发布者类 配置完发布者下来就是发布消息我们需要继承 ProducerListenerK, V 接口该接口完整信息如下 public interface ProducerListenerK, V {void onSuccess(ProducerRecordK, V producerRecord, RecordMetadata recordMetadata);void onError(ProducerRecordK, V producerRecord, RecordMetadata recordMetadata,Exception exception);}实现该接口的方法我们可以获取包含发送结果成功或失败的异步回调也就是可以在这个接口的实现中获取发送结果。 我们简单的实现构建一个发布者类接收主题和发布消息参数并打印发布结果。 Component public class KafkaProducer implements ProducerListenerObject,Object {private static final Logger producerlog LoggerFactory.getLogger(KafkaProducer.class);private final KafkaTemplateInteger, String kafkaTemplate;public KafkaProducer(KafkaTemplateInteger, String kafkaTemplate) {this.kafkaTemplate kafkaTemplate;}public void producer (String msg,String topic){ListenableFutureSendResultInteger, String future kafkaTemplate.send(topic,0, msg);future.addCallback(new KafkaSendCallbackInteger, String() {Overridepublic void onSuccess(SendResultInteger, String result) {producerlog.info(发送成功 {}, result);}Overridepublic void onFailure(KafkaProducerException ex) {ProducerRecordInteger, String failed ex.getFailedProducerRecord();producerlog.info(发送失败 {},failed);}});}}2.1.3 发布消息 写一个controller类来测试我们构建的发布者类这个类中打印接收到的消息来确保信息接收不出问题。 RestController public class KafkaTestController {private static final Logger kafkaTestLog LoggerFactory.getLogger(KafkaTestController.class);Resourceprivate KafkaProducer kafkaProducer;GetMapping(/kafkaTest)public void kafkaTest(String msg,String topic){kafkaProducer.producer(msg,topic);kafkaTestLog.info(接收到消息 {} {},msg,topic);} } 一切准备就绪我们启动程序利用postman来进行简单的测试。 进行消息发布 发布结果 可以看到消息发送成功。 我们再看看kafka消费者有没有接收到消息 看以看到kakfa的消费者也接收到了消息。 2.2 消费者 2.2.1 配置 消息的接受有多种方式我们这里选择的是使用 KafkaListener 注解来进行消息接收。它的使用像下面这样 public class Listener {KafkaListener(id foo, topics myTopic, clientIdPrefix myClientId)public void listen(String data) {...}}看起来不是太难吧但使用这个注解我们需要配置底层 ConcurrentMessageListenerContainer.kafkaListenerContainerFactor。 我们在原来的kafka配置类 KafkaConfig 中继续配置消费者大概就像下面这样 Configuration EnableKafka public class KafkaConfig {/***** 发布者 *****///生产者工厂Beanpublic ProducerFactoryInteger, String producerFactory() {return new DefaultKafkaProducerFactory(producerConfigs());}//生产者配置Beanpublic MapString, Object producerConfigs() {MapString, Object props new HashMap();props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, 192.168.2.83:9092,192.168.2.84:9092,192.168.2.86:9092);props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, IntegerSerializer.class);props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);return props;}//生产者模板Beanpublic KafkaTemplateInteger, String kafkaTemplate() {return new KafkaTemplate(producerFactory());}/***** 消费者 *****///容器监听工厂BeanKafkaListenerContainerFactoryConcurrentMessageListenerContainerInteger, StringkafkaListenerContainerFactory() {ConcurrentKafkaListenerContainerFactoryInteger, String factory new ConcurrentKafkaListenerContainerFactory();factory.setConsumerFactory(consumerFactory());factory.setConcurrency(3);factory.getContainerProperties().setPollTimeout(3000);return factory;}//消费者工厂Beanpublic ConsumerFactoryInteger, String consumerFactory() {return new DefaultKafkaConsumerFactory(consumerConfigs());}//消费者配置Beanpublic MapString, Object consumerConfigs() {MapString, Object props new HashMap();props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG,192.168.2.83:9092,192.168.2.84:9092,192.168.2.86:9092);props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, ErrorHandlingDeserializer.class);props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, ErrorHandlingDeserializer.class);props.put(ErrorHandlingDeserializer.KEY_DESERIALIZER_CLASS, JsonDeserializer.class);props.put(ErrorHandlingDeserializer.VALUE_DESERIALIZER_CLASS, JsonDeserializer.class.getName());props.put(ConsumerConfig.REQUEST_TIMEOUT_MS_CONFIG,3000);return props;} }注意要设置容器属性必须使用getContainerProperties()工厂方法。它用作注入容器的实际属性的模板 2.2.2 构建消费者类 配置好后我们就可以使用这个注解了。这个注解的使用有多种方式 1、用它来覆盖容器工厂的concurrency和属性 KafkaListener(id myListener, topics myTopic,autoStartup ${listen.auto.start:true}, concurrency ${listen.concurrency:3}) public void listen(String data) {... } 2、可以使用显式主题和分区以及可选的初始偏移量 KafkaListener(id thing2, topicPartitions { TopicPartition(topic topic1, partitions { 0, 1 }),TopicPartition(topic topic2, partitions 0,partitionOffsets PartitionOffset(partition 1, initialOffset 100))}) public void listen(ConsumerRecord?, ? record) {... } 3、将初始偏移应用于所有已分配的分区 KafkaListener(id thing3, topicPartitions { TopicPartition(topic topic1, partitions { 0, 1 },partitionOffsets PartitionOffset(partition *, initialOffset 0))}) public void listen(ConsumerRecord?, ? record) {... } 4、指定以逗号分隔的分区列表或分区范围 KafkaListener(id pp, autoStartup false,topicPartitions TopicPartition(topic topic1,partitions 0-5, 7, 10-15)) public void process(String in) {... } 5、可以向侦听器提供Acknowledgment KafkaListener(id cat, topics myTopic,containerFactory kafkaManualAckListenerContainerFactory) public void listen(String data, Acknowledgment ack) {...ack.acknowledge(); } 6、添加标头 KafkaListener(id list, topics myTopic, containerFactory batchFactory) public void listen(ListString list,Header(KafkaHeaders.RECEIVED_KEY) ListInteger keys,Header(KafkaHeaders.RECEIVED_PARTITION) ListInteger partitions,Header(KafkaHeaders.RECEIVED_TOPIC) ListString topics,Header(KafkaHeaders.OFFSET) ListLong offsets) {... } 我们这里写一个简单的只用它来接受指定主题的数据 Component public class KafkaConsumer {private static final Logger consumerlog LoggerFactory.getLogger(KafkaConsumer.class);KafkaListener(topicPartitions TopicPartition(topic kafka-topic-test,partitions 0))public void consumer (String data){consumerlog.info(消费者接收数据 {},data);} }这里解释一下因为我们进行了手动分配主题/分区所以 注解中group.id 可以为空。若要指定group.id请在消费者配置中加上props.put(ConsumerConfig.GROUP_ID_CONFIG, “bzt001”); 或在 TopicPartition 注解后加上 groupId “组id” 2.2.3 进行消息消费 继续使用postman调用我们写好的发布者发布消息观察控制台的消费者类是否有相关日志出现。
http://www.w-s-a.com/news/255822/

相关文章:

  • 可以接项目做的网站网站源码php
  • 杭州广众建设工程有限公司网站网页游戏人气排行榜
  • 上海网站开发建设最简单的网站代码
  • 东莞做网站建设免费网站建设案例
  • 莱州建设局网站wordpress的主题下载地址
  • 二级网站域名长沙企业关键词优化服务质量
  • 在家有电脑怎么做网站wordpress 入门主题
  • 什邡建设局网站sem推广是什么意思
  • 西安分类信息网站网站敏感关键词
  • 黑彩网站怎么做建设网站费用分析
  • 网站关键词选取的步骤和方法小程序商城哪家好排行榜
  • 儿童产品网站建设网站建设优化排名推广
  • 做网站的硬件无锡招标网官方网站
  • 做推送好用的网站合肥网站推广培训
  • 网站开发团队简介贵阳双龙区建设局网站
  • 新乡做网站公司哪家好wordpress侧边栏文件
  • 小白建站怎么撤销网站备案
  • 哪个网站做调查问卷赚钱短视频制作神器
  • 上海企业响应式网站建设推荐汕头网络优化排名
  • 怎么建立公司网站平台怎么将网站做成公司官网
  • 培训学校网站怎样快速建设网站模板
  • 建设电子商务网站论文云服务器安装wordpress
  • 做展板好的网站学校的网站开发过程
  • 宁波搭建网站价格西部数码网站正在建设中是什么意思
  • 吉林省建设项目招标网站苏州网络推广定制
  • 网站域名所有权证明引流推广接单
  • 做网站百度百科孟州网站建设
  • 服务网站建设企业广州模板建站系统
  • 怎么做属于自己的免费网站浏览器游戏网址
  • 上海城乡住房建设厅网站西安网站推广慧创科技