pmq再学习三

简介: 前面我们已经了解了在做好基础数据的准备工作后,启动测试的时候,会做一个注册消费组的工作,完成后,我们就可以执行生产者发消息操作了。发消息的操作是:发送消息完成后,由于其采用的拉模式,我们可以看到消息在经过发送,存储到数据库之后,会做一个通知拉取数据操作,然后执行拉取。拉取完成后,进行响应。此时会进行消费操作,而这个过程的处理关键是handleData操作,从代码中,我们可以看到其是执行的线程操作是一个batchExcute批量执行操作,可以看到其里面有一个重要方法:threadExcute方法,从而进一步看到我们想看到的方法doMessageReceived

前面我们已经了解了在做好基础数据的准备工作后,启动测试的时候,会做一个注册消费组的工作,完成后,我们就可以执行生产者发消息操作了。发消息的操作是:

@GetMapping("/test1")
publicvoidtest1(@RequestParamStringtopicName, @RequestParamintcount) {
if (Util.isEmpty(topicName)) return;
Executors.newSingleThreadExecutor().submit(newRunnable() {
@Overridepublicvoidrun() {
for (inti=1; i<count; i++) {
try {
MqClient.publish(topicName, "", newProducerDataDto(String.valueOf(i)));
       } catch (MqNotInitExceptione) {
// TODO Auto-generated catch blocke.printStackTrace();
         } catch (ContentExceed65535Exceptione) {
// TODO Auto-generated catch blocke.printStackTrace();
       }
Util.sleep(10);
     }
   }
 });
}

发送消息完成后,由于其采用的拉模式,我们可以看到消息在经过发送,存储到数据库之后,会做一个通知拉取数据操作,然后执行拉取。拉取完成后,进行响应。此时会进行消费操作,而这个过程的处理关键是handleData操作,从代码中,我们可以看到其是执行的线程操作是一个batchExcute批量执行操作,可以看到其里面有一个重要方法:threadExcute方法,从而进一步看到我们想看到的方法doMessageReceived,这个方法会调用我们自定义的方法实现消费。

// 执行消费操作

@OverridepublicList<Long>onMessageReceived(List<MessageDto>messages) {
try {
// 执行消息消费TransactioncatTransaction=null;
System.out.println("开始接收生产者发送过来的消息");
for (MessageDtomessageDto : messages) {
// 执行消息消费System.out.println("当前接收到的消息是messageDto消费组:"+messageDto.getConsumerGroupName() +" "+"当前接收的消费主题:"+messageDto.getTopicName()
\+" "+"当前接收到的消息:"+messageDto.getBody());
   }
System.out.println("接收成功");
 } catch (Exceptione) {
// TODO Auto-generated catch blocke.printStackTrace();
 }
returnnull;
}

而从消息的结果可以看到其打印出来的消费消息。


目录
相关文章
|
3月前
|
Linux
RISCV学习
RISCV学习
|
设计模式 安全 Java
【鸟瞰】C#的学习
前言: 在软件工程之C/S学习的过程中,我们已经学习过了软件工程,文档,九种UML图。下一个学习小阶段是C#和设计模式,视频里的老师上来就讲“.NET”,还说应该念成“dot Net”,念成“点NET”实在是太不专业了。我突然有点蒙圈了,为啥在这个阶段要学习C#?学C#为啥还和“dot Net”有关?怎么这么多C?什么C语言?C ++?C#?这些都是些什么鬼?晕!!! 于是开始在培养计划中寻找答案。。。
|
弹性计算 Linux 数据安全/隐私保护
|
网络协议 前端开发 Windows
学习分享系列(一):记日常学习中遇到的两个问题
学习分享系列(一):记日常学习中遇到的两个问题
学习分享系列(一):记日常学习中遇到的两个问题
了解自己的学习
关于“学习”的相关总结
505 0
|
弹性计算 Java 关系型数据库
学习介绍
解压tomcat压缩包 tar -zxvf apache-tomcat-8.5.70.tar.gz。 解 在idea将下面打包成war,通过命令传到服务器的tomcat里面,传进去后将会自己解压 通过这次的云服务器ECS的使用,我收获颇丰,第一次将项目放到了服务器上进行访问,在过程中,因为我目前使用的springboot,所以在tomcat上面使用较少,遇到大多数问题是部署到云服务器上端口以及连接的错误和Linux指令的不熟悉,我经常通过网络找各种解决办法,配置端口,删除重新解压一下,最后才能使用,将这次的心得体会写下来,以后再次使用阿里云服务器的时候,我看看通过这个文章,可以更快的部署服务器
|
弹性计算 算法 小程序
我是自愿学习的
沉迷学习 日渐消瘦
我是自愿学习的
|
人工智能
|
Android开发
最新学习发现的好文章
1、即可学院关于 View 动画和属性动画的详解,对于使用方法讲解的超详细,里面也涉及了一部分的源码,如果想查看源码的话还是自己动手丰衣足食吧。这些文章主要都是用法和基本原理。Android 动画详解;
730 0