java
2021-02-18
2021-02-18
万物各得其和以生,各得其养以成。一一《荀子》
介绍
使用异步多线程方案会导致CPU
竞争强烈,故使用MQ
使用MQ
能够大大降低项目耦合
名词:
Producer
:生产者,发消息的
Consumer
:消费者,收消息干活的
Broker
:MQ
本体
Topic
:主题
Queue
:消息队列,先进先出
Message
:消息报文(内容,一般为json
)
单机版本MQ
原理
1 | package com.ruben.mq; |
宕机如何保证
MQ
消息不丢失
主流MQ
都自带持久化策略,不用担心消息丢失
消费者不在,消息是否会丢失
不会,因为存在消息确认机制,必须要消费者消费该消息成功之后,再通知mq
删除
MQ
服务器端将消息推送给消费者:消费者已经和MQ
保持了长连接
消费者主动拉取消息:消费者首次启动
抗高并发:消费者根据自身能力情况拉取MQ
消息消费,默认情况取出一条
提高速率:消费者实现集群;批量获取消息消费
安装
首先安装Erlang
语言,官网下载
我这里选了个19.1版本
然后安装
一直下一步就行
然后配置环境变量
然后把%ERLANG_HOME%\bin;
添加到Path
末尾
然后确定
打开控制台,输入erl -version
查看版本
如果成功提示版本则表明环境变量生效
然后下载安装RabbitMQ
,官网下载
我这里用的3.6.9
版本,因为提前下好了
一直下一步就可以了
找到安装目录,我这里是C:\Program Files\RabbitMQ Server\rabbitmq_server-3.6.9\sbin
执行
1 | // 安装管理界面插件 |
然后我们访问http://127.0.0.1:15672/
即可进入