系列文章(更新ing):

「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现

「 从0到1学习微服务SpringCloud 」03 Eureka的自我保护机制

「 从0到1学习微服务SpringCloud 」04服务消费者Ribbon+RestTemplate

「 从0到1学习微服务SpringCloud 」05消费者Fegin

「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config

在上篇文章中,我们已经用到了MQ,用于实现配置自动刷新。接下来,就具体说说MQ的应用场景以及RabbtMq的基本使用。

MQ应用场景

  • 异步处理

    比如用户注册之后,需要加积分和发短信。就可以在用户信息入库后,通过异步消息让积分服务和短信服务做它们的事,用户无需等待这个过程,从而提高用户体验。

  • 流量削峰

    最常见的是秒杀场景,一般会因为流量暴增,甚至应用挂掉。为解决这种情况,需要在应用前端加入消息队列。服务器接收用户的请求后,首先写入消息队列。假如消息队列长度超过最大数量,则直接抛弃用户请求或跳转到错误页面。

  • 日志处理

    最典型的就是kafka,kafka最初的设计就是为了日志处理,大数据里用得特别多。通过日志采集,定时写入kafka队列,然后kafka对日志进行接收,储存和转发

  • 应用解耦

    比如用户下单后,订单系统需要通知库存系统。传统的做法是,订单系统调用库存系统的接口。但假如库存系统无法访问,则订单减库存将失败,从而导致订单失败,订单系统与库存系统耦合。引入应用消息队列后,用户下单后,订单系统完成持久化处理,将消息写入消息队列,返回用户订单下单成功,库存系统阅下单的消息,进行库存操作。在下单时库存系统不能正常使用。也不影响正常下单,因为下单后,订单系统写入消息队列就不再关心其他的后续操作了。实现订单系统与库存系统的应用解耦

  • 消息通讯

    消息通讯是指,消息队列一般都内置了高效的通信机制,因此也可以用在纯的消息通讯。比如实现点对点消息队列,或者聊天室等

基本使用

继续使用eureka-client项目

1.添加maven

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

2.添加配置

spring:
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest

3.Mq接收-发送

有3种接收方式,我这里为了方便,在同一个应用中写的发送和接收,大家可以想象一下它们是在不同应用中,如下

3.1 不自动创建Queue,需要在Mq手动建立对应名字的队列,否则会报"找不到队列"的错误

//接收消息
@Log4j2
@Component
public class MqReceiver {
//不会自动创建队列
@RabbitListener(queues = "myQueue1")
public void receiver1 (String message){
log.info("MqReceiver1: {}", message);
}
}
//发送消息
@RunWith(SpringRunner.class)
@SpringBootTest
public class MqSenderTest{
@Autowired
private AmqpTemplate amqpTemplate; @Test
public void send1(){
amqpTemplate.convertAndSend("myQueue1","Hello!Mq Message!");
}
}

3.2 若Mq中无相应名称的队列,会自动创建Queue

//接收消息
@RabbitListener(queuesToDeclare = @Queue("myQueue2"))
public void receiver2 (String message){
log.info("MqReceiver2: {}", message);
}
//发送消息
@Test
public void send2(){
amqpTemplate.convertAndSend("myQueue2","Hello!Mq Message!");
}

3.3 消息队列分组,将不同的队列归为一组,以不同关键字区分(会自动创建队列)

这里以订单服务为例,假设现有两种订单,一种是数码订单,另一种是水果订单,数码供应商和水果供应商两个服务同时订阅订单服务,但数码供应商只关心数码订单,水果供应商只关心水果订单,这里就需要对订单消息进行分类了

//接收消息
/**
* 数码供应商服务 接收消息
* @param message
*/
@RabbitListener(bindings = @QueueBinding(
exchange = @Exchange("myOrder"),//相当于分组名
key = "computer",//相当于分类名
value = @Queue("computerQueue")
))
public void computerReceiver (String message){
log.info("computerReceiver: {}", message);
} /**
* 水果供应商服务 接收消息
* @param message
*/
@RabbitListener(bindings = @QueueBinding(
exchange = @Exchange("myOrder"),//相当于分组名
key = "fruit",//相当于分类名
value = @Queue("fruitQueue")
))
public void fruitReceiver (String message){
log.info("fruitReceiver: {}", message);
}
//发送消息
@Test
public void sen4(){
amqpTemplate.convertAndSend("myOrder","computer","computer Order!");
} @Test
public void sen5(){
amqpTemplate.convertAndSend("myOrder","fruit","fruit Order!");
}

4.启动eureka-client,eureka-server,config应用,运行刚才写的单元测试

发送接收消息成功啦!

如果觉得不错,分享给你的朋友!

THANDKS

  • End -

一个立志成大腿而每天努力奋斗的年轻人

伴学习伴成长,成长之路你并不孤单!

「 从0到1学习微服务SpringCloud 」07 RabbitMq的基本使用的更多相关文章

  1. 「 从0到1学习微服务SpringCloud 」10 服务网关Zuul

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...

  2. 「 从0到1学习微服务SpringCloud 」09 补充篇-maven父子模块项目

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...

  3. 「 从0到1学习微服务SpringCloud 」08 构建消息驱动微服务的框架 Spring Cloud Stream

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  4. 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  5. 「 从0到1学习微服务SpringCloud 」05服务消费者Fegin

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  6. 「 从0到1学习微服务SpringCloud 」04服务消费者Ribbon+RestTemplate

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  7. 「 从0到1学习微服务SpringCloud 」03 Eureka的自我保护机制

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 Eureka的高可用需要 ...

  8. 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! Spring Cloud Eureka 基于Netflix Eureka做了二次封装(Spring Clo ...

  9. 「 从0到1学习微服务SpringCloud 」01 一起来学呀!

    有想学微服务的小伙伴没?一起来从0开始学习微服务SpringCloud,我会把学习成果总结下来,供大家参考学习,有兴趣可以一起来学!如有错误,望指正! Spring .SpringBoot.Sprin ...

随机推荐

  1. codeforces 677D(分层图dp)

    Codeforces 677D 传送门:https://codeforces.com/contest/677/problem/D 题意: 给你一个n*m的方格图,每个点有一个权值val,现在要求你从坐 ...

  2. Apache的DBUtils框架学习(转)

    一.commons-dbutils简介 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用dbutils能极大简化 ...

  3. 关于python2和python3除法的区别

    在Python2中,除法的取值结果取整数 >>> 9/2 4 而在Python3中,除法/的结果包含小数,如果只想取整数需要使用// >>> 9/2 4.5 > ...

  4. AI炼丹 - 深度学习必备库 numpy

    目录 深度学习必备库 - Numpy 1. 基础数据结构ndarray数组 1.1 为什么引入ndarray数组 1.2 如何创建ndarray数组 1.3 ndarray 数组的基本运算 1.4 n ...

  5. react-native-swiper使用的坑

    今天使用引入react-native-swiper组件使用轮播图时,发现报如下错误: Invarint Violation:ViewPagerAndroid has been removed from ...

  6. 搜索排序-learning to Rank简介

    Learning to Rank pointwise \[ L\left(f ; x_{j}, y_{j}\right)=\left(y_{j}-f\left(x_{j}\right)\right)^ ...

  7. vue实现下拉框全选和输入匹配

    实际项目中的一个需求: 点击文本框,弹出带有复选框的选项,然后获取选中项的数据,传给后面的一个功能.在文本框输入内容,也会动态的匹配下拉列表,并且列表带有全选功能. 朴素的效果图: 我选择了用vue实 ...

  8. JVM性能优化系列-(1) Java内存区域

    1. Java内存区域 1.1 运行时数据区 Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域.主要包括:程序计数器.虚拟机栈.本地方法栈.Java堆.方法区(运 ...

  9. jenkins+ant+jmeter自动化环境搭建

    jmeter:测试接口的工具,支持java语言: ant:Apache Ant是一个Java库和命令行工具,其任务是将构建文件中描述的进程作为相互依赖的目标和扩展点.只要使用过Linux系统的读者,应 ...

  10. Web开发学习目录

    1.MyBaits 1.1mybatis学习入门 1.2mybatis学习之CURD 1.3mybatis学习之连接池 1.4mybatis学习之动态SQL 1.5mybatis学习之多表操作 1.6 ...