RabbitMQ

偶然发现自己写的博客还有点用,偶尔忘记点知识,还能上来看看很方便(虽然大部分需要看收藏,百度),慢慢来吧。

目录

1.同步调用和异步调用

2.MQ技术选型

3.rabbitmq 介绍和安装

安装

相关概念介绍

4.快速入门

5.虚拟主机,实现数据隔离

6.消息堆积可以用Work Queues 

7.交换机

7.1 Fanout交换机

7.2 Direct交换机

7.3 Topic交换机


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教程。

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值