RabbitMQ

Windows下安装RabbitMQ需要以下几个步骤:

(1)下载erlang 下载地址:http://www.erlang.org/downloads

原因在于RabbitMQ服务端代码是使用并发式语言erlang编写的,双击.exe文件进行安装,安装完成之后创建一个名为ERLANG_HOME的环境变量,其值指向erlang的安装目录,同时将%ERLANG_HOME%\bin加入到Path中,最后打开命令行,输入erl,如果出现erlang的版本信息就表示erlang语言环境安装成功;

(2)下载RabbitMQ 下载地址:http://www.rabbitmq.com/

同样双击.exe进行安装就好(这里需要注意一点,默认的安装目录是C:/Program Files/...,这个目录中存在空格符,RabbitMQ安装目录中是不允许有空格的,我们需要改变安装目录(大坑);

(3)安装RabbitMQ-Plugins

这个相当于是一个管理界面,方便我们在浏览器界面查看RabbitMQ各个消息队列以及exchange的工作情况,安装方法是:打开命令行cd进入rabbitmq的sbin目录,输入:rabbitmq-plugins enable rabbitmq_management 命令,plugins安装成功;

(4)插件安装完之后,在浏览器输入 http://localhost:15672 ,输入用户名:guest,密码:guest,就可以进入管理界面了;

RabbitMQ概念

producer:消息生产者

consumer:消息消费者

virtual host:虚拟主机,在RabbitMQ中,用户只能在虚拟主机的层面上进行一些权限设置,比如我可以访问哪些队列,我可以处理哪些请求等等;

broker:消息转发者,也就是我们RabbitMQ服务端充当的功能了,那么消息是按照什么规则进行转发的呢?需要用到下面几个概念;

exchange:交换机,他是和producer直接进行打交道的,有点类似于路由器的功能,主要就是进行转发操作的呗,那么producer到底用哪个exchange进行路由呢?这个取决于routing key(路由键),每个消息都有这个键,我们也可以自己设定,其实就是一字符串;

queue:消息队列,用于存放消息,他接收exchange路由过来的消息,我们可以对队列内容进行持久化操作,那么queue到底接收那个exchange路由的消息呢?这个时候就要用到binding key(绑定键)了,绑定键会将队列和exchange进行绑定

大佬总结:https://blog.csdn.net/lmj623565791/category_2386657.html

常用命令

添加开机启动RabbitMQ服务

chkconfig rabbitmq-server on

启动服务

/sbin/service rabbitmq-server start

查看服务状态

/sbin/service rabbitmq-server status

停止服务(选择执行)

/sbin/service rabbitmq-server stop

开启web管理插件

rabbitmq-plugins enable rabbitmq _management

创建用户

创建账号

rabbitmqctl add_user admin 123

设置用户角色

rabbitmqctl set_user_tags admin administrator

设置用户权限

set_permissions [-p ]

rabbitmactl set_permissions -p "/" admin "." ". " ".*"

用户user_admin具有/vhost1这个virtual host中所有资源的配置、写、读权限

当前用户和角色

rabbitmqctl list_users

RabbitMQ简单使用

producer(生产者)端步骤:

(1):创建ConnectionFactory,并且设置一些参数,比如hostname,portNumber等等

(2):利用ConnectionFactory创建一个Connection连接

(3):利用Connection创建一个Channel通道

(4):创建queue并且和Channel进行绑定

(5):创建消息,并且发送到队列中

注意,在我们当前的例子中,并没有用到exchange交换机,RabbitMQ默认情况下是会创建一个空字符串名字的exchange的,如果我们没有创建自己的exchange的话,默认就是使用的这个exchange;

producer端代码:

java 复制代码
public class Sender {
	private final static String QUEUE_NAME = "MyQueue";
public static void main(String[] args) {
	send();
}

public static void send()
{
	ConnectionFactory factory = null;
	Connection connection = null;
	Channel channel = null;
	try {
		factory = new ConnectionFactory();
		factory.setHost("localhost");
		connection = factory.newConnection();
		channel = connection.createChannel();
		channel.queueDeclare(QUEUE_NAME, false, false, false, null);
		String message = "my first message .....";
		channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));
		System.out.println("已经发送消息....."+message);
	} catch (IOException e) {
		e.printStackTrace();
	} catch (TimeoutException e) {
		e.printStackTrace();
	}finally{
		try {
			//关闭资源
			channel.close();
			connection.close();
		} catch (IOException e) {
			e.printStackTrace();
		} catch (TimeoutException e) {
			e.printStackTrace();
		}
	}
}
}

consumer(消费者)端步骤:

(1):创建ConnectionFactory,并且设置一些参数,比如hostname,portNumber等等

(2):利用ConnectionFactory创建一个Connection连接

(3):利用Connection创建一个Channel通道

(4):将queue和Channel进行绑定,注意这里的queue名字要和前面producer创建的queue一致

(5):创建消费者Consumer来接收消息,同时将消费者和queue进行绑定

consumer端代码:

java 复制代码
public class Receiver {
	private final static String QUEUE_NAME = "MyQueue";
public static void main(String[] args) {
	receive();
}

public static void receive()
{
	ConnectionFactory factory = null;
	Connection connection = null;
	Channel channel = null;
	
	try {
		factory = new ConnectionFactory();
		factory.setHost("localhost");
		connection = factory.newConnection();
		channel = connection.createChannel();
		channel.queueDeclare(QUEUE_NAME, false, false, false, null);
		Consumer consumer = new DefaultConsumer(channel){
			@Override
			public void handleDelivery(String consumerTag, Envelope envelope, BasicProperties properties,
					byte[] body) throws IOException {
				System.out.println("11111111111");
				String message = new String(body, "UTF-8");
				System.out.println("收到消息....."+message);
			}};
		channel.basicConsume(QUEUE_NAME, true,consumer);
	} catch (IOException e) {
		e.printStackTrace();
	} catch (TimeoutException e) {
		e.printStackTrace();
	}finally{
		try {
			//关闭资源
			channel.close();
			connection.close();
		} catch (IOException e) {
			e.printStackTrace();
		} catch (TimeoutException e) {
			e.printStackTrace();
		}
	}
}
相关推荐
茶杯梦轩2 天前
从零起步学习RabbitMQ || 第三章:RabbitMQ的生产者、Broker、消费者如何保证消息不丢失(可靠性)详解
分布式·后端·面试
回家路上绕了弯4 天前
深入解析Agent Subagent架构:原理、协同逻辑与实战落地指南
分布式·后端
用户8307196840824 天前
Spring Boot 集成 RabbitMQ :8 个最佳实践,杜绝消息丢失与队列阻塞
spring boot·后端·rabbitmq
用户8307196840826 天前
RabbitMQ vs RocketMQ 事务大对决:一个在“裸奔”,一个在“开挂”?
后端·rabbitmq·rocketmq
初次攀爬者7 天前
RabbitMQ的消息模式和高级特性
后端·消息队列·rabbitmq
初次攀爬者9 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
让我上个超影吧10 天前
消息队列——RabbitMQ(高级)
java·rabbitmq
塔中妖10 天前
Windows 安装 RabbitMQ 详细教程(含 Erlang 环境配置)
windows·rabbitmq·erlang
断手当码农10 天前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
初次攀爬者10 天前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端