偶然发现自己写的博客还有点用,偶尔忘记点知识,还能上来看看很方便(虽然大部分需要看收藏,百度),慢慢来吧。
目录
1.同步调用和异步调用
异步调用具有下列优势:
- 应用解耦,扩展性强
- 无需等待,性能好
- 缓存消息,流量削峰填谷
- 故障隔离
2.MQ技术选型
- RabbitMQ
- RocketMQ
- ActiveMQ
- kafka
既然这篇文章写rabbitmq,肯定选rabbitmq了
3.rabbitmq 介绍和安装
安装
选择docker方式安装,首先下载rabbitmq镜像,本人选择了mq3.8版本,可在网上寻找资源自行下载。
本机具备docker环境后,执行以下命令:
docker run \
--name rabbitmq \
-e RABBITMQ_DEFAULT_USER=feng \
-e RABBITMQ_DEFAULT_PASS=123321 \
-v mq-plugins:/plugins \
--hostname master \
-p 5672:5672 \
-p 15672:15672 \
--network mqnet \
-d \
rabbitmq:3.8-management
安装完成之后,打开浏览器输入IP:15672(记得关闭防火墙),出现如下页面即可
输入运行容器时设定的用户名和密码,登录进首页
相关概念介绍
Connection 就是tcp 连接,消费者和生产者首先得连接到broker (broker可以理解为rabbit 服务)
Channel 就是tcp 连接多线程使用,因为tcp 连接可被多个线程共享,大大提高了并发性,这个代码中自动配置(rabbit template)
4.快速入门
快速入门里学习了
创建队列
路由器(fanout)模拟发送消息,看队列能不能收到信息
注意:路由器需要绑定队列才能发送成功(路由只是转发消息,并不存储消息。)
5.虚拟主机,实现数据隔离
添加用户
添加虚拟主机
添加后,如下图
6.消息堆积可以用Work Queues
多个消费者绑定一个队列(加快消费速度,提升性能)
同一条消息只会被一个消费者处理
且不同服务器处理时间不同,可以设置prefetch 参数控制消费者预取的消息数量,处理完一条再处理下一条,实现能者多劳。
除了work queues外,还可以通过优化代码来让消费者更快速的消费消息,比如java语言的异步处理。(注意是java异步,不是mq,否则这不套娃吗)
7.交换机
7.1 Fanout交换机
Fanout:广播,生产者的消息可以发送给多个绑定到此路由的队列。就比如大喇叭,一喊都可以听见。
案例:
7.2 Direct交换机
创建Direct交换机
绑定队列,一次只能绑定一个key,多个key的话绑定多次,见下图
Direct相较Fanout更强大,相同routingkey就可以实现Fanout效果(比如routingkey=red,direct.queue1和direct.queue2都能收到,因为这两队列都绑定了red)
不同的key发送给不同的队列(routingkey=blue,只有direct.queue1可以收到)
应用场景比如只有订单支付成功了,才会发消息给短信通知服务。
7.3 Topic交换机
china.#表示china开头的routingkey都可以匹配,比如china.news,而且再细化的routingkey也可以匹配,因为#代指0或多个单词,比如china.news.sport(体育新闻)
案例:
创建topic交换机
重点:
本文参考自b站黑马程序员rabbitmq教程。