1.RabbitMQ架构图
data:image/s3,"s3://crabby-images/c055e/c055e37be93684654dd61e26153b09cc28370824" alt=""
-
publisher
:生产者,也就是发送消息的一方 -
consumer
:消费者,也就是消费消息的一方 -
queue
:队列,存储消息。生产者投递的消息会暂存在消息队列中,等待消费者处理 -
exchange
:交换机,负责消息路由。生产者发送的消息由交换机决定投递到哪个队列。 -
virtual host
:虚拟主机,起到数据隔离的作用。每个虚拟主机相互独立,有各自的exchange、queue
2.模拟收发消息
一.交换机
data:image/s3,"s3://crabby-images/cea32/cea324dbe22c727a93435f3973364271fc6829f9" alt=""
1.进去任意一个交换机,模拟生产者发送消息
data:image/s3,"s3://crabby-images/2a126/2a126d555ed9d29dadb7af83b20fd139d6634e14" alt=""
2.由于没有消费者存在,最终消息丢失了,这样说明交换机没有存储消息的能力。
data:image/s3,"s3://crabby-images/a0bc3/a0bc396ca76b41e0eaa8955196ebfae6266b7a2a" alt=""
二.队列
1.添加两个队列:hello.queue1与hello.queue2
data:image/s3,"s3://crabby-images/d851e/d851e47641dac069fdc038624ce19270871fd1c4" alt=""
data:image/s3,"s3://crabby-images/8d44a/8d44a25e418757a0dd5f68fff60334fe436a0401" alt=""
2.交换机与消息队列绑定
data:image/s3,"s3://crabby-images/1b5e3/1b5e371e4392de28be6766ef585eb82f8db48fbf" alt=""
3.交换机再次发送消息
data:image/s3,"s3://crabby-images/23bc3/23bc3acb1870a8fe0a417d74457e440f597717ef" alt=""
data:image/s3,"s3://crabby-images/f322a/f322a92d751766da9320eb00bce1eda13b447596" alt=""
此时若有消费者监听了MQ的hello.queue1
或hello.queue2
队列,就会消费该消息。
3.数据隔离
1.用户管理:
data:image/s3,"s3://crabby-images/0f2dc/0f2dc166105b0380ac1dde0f39664c818874d717" alt=""
这里的用户都是RabbitMQ的管理或运维人员。
-
Name
:itheima
,也就是用户名 -
Tags
:administrator
,说明itheima
用户是超级管理员,拥有所有权限 -
Can access virtual host
:/
,可以访问的virtual host
,这里的/
是默认的virtual host
当多个项目同时使用时,为了避免互相干扰,可以利用virtual host的隔离特性,将不同的项目隔离
2.virtual host
1.添加一个用户(此时没有设置virtual host)
data:image/s3,"s3://crabby-images/24eeb/24eebc7f4e5731ba7be38c21d4b3bfdf9352fb1f" alt=""
2.切换用户为新建的用户
data:image/s3,"s3://crabby-images/e73c8/e73c8cb72fa9fa05f1337e368eb64c3d2d1bded0" alt=""
3.添加一个单独的virtual host
data:image/s3,"s3://crabby-images/20004/2000423a6c1655160a755fa1750bc310268dcd2a" alt=""
data:image/s3,"s3://crabby-images/22355/223553d688a5ec5d3d0306f7566766c75948a221" alt=""
4.切换virtual host路径(此时便将/的消息队列隔离了)
data:image/s3,"s3://crabby-images/48d7a/48d7ae6894152a59edb72ac39c51f31493219f6f" alt=""
data:image/s3,"s3://crabby-images/fe079/fe079509c1536ae69a9ee6ecd7321d1d4b2e4552" alt=""