本系列是「RabbitMQ实战:高效部署分布式消息队列」书籍的总结笔记。
关注我的微信公众号:情情说,查看更多文章 ~
上一篇介绍了AMQP消息通信,包括队列、交换器和绑定,通过虚拟主机还可以隔离数据和权限,消息持久化和发送方确认模式确保了消息不丢失。
本篇主要介绍如何运行和管理RabbitMQ,在介绍之前,会有个DEMO演示消息发送和接收,一方面对AMQP的元素有更直观的认识,一方面为后面介绍监控做数据来源。
通过介绍,你会了解到:
- 消息发送和接收简单实现
- 服务器管理-启动和停止节点
- 权限配置
- 使用统计
消息发送和接收简单实现
该Demo主要用于收集日志,消息发送者是各个应用子系统,消息接收者是日志收集服务,使用RabbitMQ可以很容易实现。
基于Spring Boot框架实现,主要类的作用如下:
- LogRabbitConfig:创建队列、交换器、绑定等初始化操作;
- Sender:消息发送者;
- AllReceiver:所有级别日志接收者,接收所有级别的日志;
- ErrorReceiver:错误级别日志接受者,只接收错误级别的日志;
- LogSenderTest:测试用例类;
消息模型如下:
配置
首先,配置spring boot和rabbitmq依赖:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.1.RELEASE</version>
<relativePath/>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--rabbitmq依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
</dependencies>
然后在application.properties文件中配置rabbitmq地址:
spring.rabbitmq.host=127.0.0.1
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
spring.rabbitmq.publisher-confirms=true
spring.rabbitmq.virtual-host=/
LogRabbitConfig实现
使用Spring的@Configuration定义配置类,可替换xml配置文件,被注解的类内部包含有一个或多个被@Bean注解的方法,用于构建bean定义,初始化Spring容器。
@Configuration
public class LogRabbitConfig {
final static String QUEUE_LOG_ERROR = "log.error";
final static String QUEUE_LOG_ALL = "log.all";
//创建log.error队列
@Bean
public Queue logError() {
return new Queue(QUEUE_LOG_ERROR);
}
//创建log.all队列
@Bean
public Queue logAll() {
return new Queue(QUEUE_LOG_ALL);
}
//创建exchange,命名为log
@Bean
TopicExchange exchange() {
return new TopicExchange("log");
}
//绑定log.error队列到exchange,routingkey为log.error
@Bean
Binding bindingExchangeError(Queue logError, TopicExchange exchange) {
return BindingBuilder.bind(logError).to(exchange).with("log.error");
}
//绑定log.all队列到exchange,routingkey为log.#
@Bean
Binding bindingExchangeAll(Queue logAll, TopicExchange exchange) {
return BindingBuilder.bind(logAll).to(exchange).with("log.#");
}
}
Sender实现
各个子系统向rabbitmq服务器发送消息:
@Component
public class Sender {
@Autowired
private AmqpTemplate rabbitTemplate;
public void send() {
//向mq服务端发送消息,exchange为log,routingkey为log.error
String context = "error log";
this.rabbitTemplate.convertAndSend("log", "log.error", context);
//向mq服务端发送消息,exchange为log,routingkey为log.info
context = "info log";
System.out.println("send msg : " + context);
this.rabbitTemplate.convertAndSend("log", "log.info", context);
//向mq服务端发送消息,exchange为log,routingkey为log.warn
context = "warn log";
System.out.println("send msg : " + context);
this.rabbitTemplate.convertAndSend("log", "log.warn", context);
}
}
AllReceiver和ErrorReceiver实现
从rabbitmq服务器接收消息。
AllReceiver从服务器的log.all队列获取消息,因为它绑定的routingkey为”log.#”,所以,会收到所有级别的日志:
@Component
@RabbitListener(queues = "log.all")
public class AllReceiver {
@RabbitHandler
public void process(String context) {
System.out.println("receive log : " + context);
}
}
ErrorReceiver从服务器的log.error队列获取消息,因为它绑定的routingkey为”log.error”,所以,只会收到error级别的日志:
@Component
@RabbitListener(queues = "log.error")
public class ErrorReceiver {
@RabbitHandler
public void process(String context) {
System.out.println("receive error : " + context);
}
}
LogSenderTest测试用例
测试用例很简单,就是调用Sender发送消息,观察消息的接收情况。
@RunWith(SpringRunner.class)
@SpringBootTest
@SpringBootApplication
public class LogSenderTest {
@Autowired
Sender sender;
@Test
public void sendLog() {
sender.send();
}
}
运行日志如下:
可以看到,error收到了2次,说明exchange同时分发给了log.all和log.error队列,其他级别的日志分发给了log.all队列。
服务器管理-启动和停止节点
RabbitMQ是用Erlang编写的,Erlang天生就能让应用程序无需知道对方是否在同一台机器上即可相互通信,这让集群和可靠的消息路由变得简单。
理解节点和Erlang应用程序
和Java有JVM虚拟机类似,Erlang也有虚拟机,虚拟机的每个实例称之为「节点」,不同的是,多个Erlang应用程序可以运行在同一个节点之上,如果应用程序崩溃了,Erlang节点会自动尝试自动重启应用程序。
节点的操作:
- 后台启动节点:./rabbitmq-server -detached
- 停止节点:./rabbitmqctl stop
- 仅停止rabbit应用程序:./rabbitmqctl stop_app
配置文件
配置文件的格式本质上是原始的Erlang数据结构,是一个包含了嵌套哈希表的数组,如下:
[
[mnesia , [{dump_log_write_threshold , 1000}]],
[rabbit , [{vm_memory_high_wateremark , 0.4}]]
]
上面配置了2个应用,每个应用会有自己的哈希表来配置选项:
- mnesia:是rabbitmq用来存储交换器和队列元数据的;
- rabbit:是rabbitmq特定的配置选项;
每个应用如果有多个选项,用逗号隔开。
权限配置
RabbitMQ权限系统中,单个用户可以跨越多个vhost进行授权,而且可以对读、写、配置分别授权。
首先创建一个用户dongqingqing,密码为123456:
./rabbitmqctl add_user dongqingqing 123456
授予dongqingqing用户权限,可以读取所有队列和交换器,只可写log.*格式的队列和交换器,无法创建或删除队列和交换器
./rabbitmqctl set_permissions dongqingqing ".*" "log.*" ""
set_permissions 后面的参数分别为用户名、读权限、写权限、配置权限。
其他详细用法可查看文档。
使用统计
查看数据统计
可通过rabbitmqctl命令查看数据统计信息,比如队列和消息数目、交换器和绑定等。
查看所有队列,包含上面demo定义的log.all和log.error:
查看所有交换器,包含上面demo定义的log
另外,rabbitmq提供了管理界面插件,更方便的查看各种统计,可以通过下面的命令开启:
sudo ./rabbitmq-plugins enable rabbitmq_management
查看日志
可以在文件系统中查看日志,启动rabbitmq后,会显示日志的路径:
另外,可以通过AMQP获取实时日志信息,有一个amq.rabbitmq.log的topic交换器,监听对应的队列即可。
下一篇将介绍消息通信模式和最佳实践,感谢大家持续关注。
欢迎扫描下方二维码,关注我的个人微信公众号 ~
相关推荐
**RabbitMQ实战:高效部署分布式消息队列** 在当今的软件开发中,消息队列作为异步处理和系统解耦的重要工具,被广泛应用。RabbitMQ作为一个开源的消息代理和队列服务器,以其稳定性和易用性赢得了广大开发者的好评...
《RabbitMQ实战:高效部署分布式消息队列》是一本专为希望深入理解和应用RabbitMQ的IT从业者准备的指南。RabbitMQ是一款开源的消息代理软件,它在分布式系统中承担着消息中间件的角色,负责处理应用程序之间的通信,...
**RabbitMQ实战:高效部署分布式消息队列** 在当今的IT行业中,分布式系统和微服务架构变得越来越普遍,而消息队列作为这些系统中的重要组件,承担着数据同步、异步处理、解耦和负载均衡等关键任务。RabbitMQ,作为...
通过阅读《RabbitMQ实战 高效部署分布式消息队列》这本书,开发者可以深入了解RabbitMQ的使用技巧,掌握如何在实际项目中高效地部署和管理消息队列,从而提高系统的稳定性和可靠性。结合提供的38套Java高级架构视频...
《RabbitMQ实战高效部署分布式消息队列》这本书籍详细阐述了如何在实际环境中高效地部署和使用RabbitMQ这一流行的消息中间件。RabbitMQ是基于AMQP(Advanced Message Queuing Protocol)协议实现的开源消息队列系统...
通过学习RabbitMQ实战指南,你可以掌握如何在实际项目中运用RabbitMQ,实现高效、可靠的异步通信,提升系统的稳定性和可扩展性。在实践中,结合具体的业务场景,灵活运用上述知识,将有助于构建出更加健壮的分布式...
随书源码“RabbitMQ实战-随书源码”和“RabbitMQ in action 和 RabbitMQ实战-高效部署分布式消息队列”的配套代码,提供了丰富的示例,帮助读者深入理解RabbitMQ的使用和实践。 1. **RabbitMQ基础** - **AMQP协议*...
RabbitMQ是一款开源的消息中间件,它基于AMQP(Advanced Message Queuing Protocol)协议实现,广泛应用于分布式系统中,...通过深入学习和实践,我们可以高效地部署和管理分布式消息队列,提升系统的稳定性和可靠性。
**RabbitMQ实战指南** RabbitMQ是一种广泛使用的开源消息代理和队列服务器,它基于AMQP(Advanced Message Queuing Protocol)协议,旨在提供可靠、高效的消息传递服务。本实战指南将带你深入理解RabbitMQ的核心...
**RabbitMQ实战——高效部署分布式消息队列** 在当今的软件开发中,消息队列(Message Queue,MQ)已经成为构建可扩展、高可用系统的关键组件。RabbitMQ,作为一个开源的消息代理和队列服务器,被广泛应用于各种...
RabbitMQ是一款开源的消息队列服务软件,它...综上所述,RabbitMQ作为一款消息队列服务软件,其下载、安装、配置和使用过程较为复杂,本指南提供了详细的步骤和解释,帮助用户更好地掌握如何部署和管理RabbitMQ服务。
在本PDF中,你将了解到如何有效地部署和管理RabbitMQ,从而实现高性能的分布式消息队列。 首先,RabbitMQ的基础概念是理解其工作原理的关键。RabbitMQ基于AMQP(Advanced Message Queuing Protocol)协议,这是一个...
### RabbitMQ实战知识点详解 #### 一、RabbitMQ简介及背景 - **RabbitMQ开发语言**: Erlang,一种面向并发的编程语言,非常适合处理大量并发连接。 - **AMQP**: 先进的消息队列协议(Advanced Message Queuing ...
在这个“RabbitMQ实战视频”压缩包中,你将找到一系列关于RabbitMQ的实战教程,包括视频讲解、源代码示例以及相关的文档资料,帮助你深入理解和应用这个强大的工具。 1. **消息队列基础**:了解消息队列的基本概念...
【RabbitMQ实战】 RabbitMQ 是一个开源的消息代理和队列服务器,它基于 AMQP(Advanced Message Queuing Protocol)协议实现,广泛应用于分布式系统中,用于解耦生产者和消费者的处理流程,提高系统的可扩展性和...
4. **管理控制台**:默认情况下,RabbitMQ提供了一个Web管理界面,可以通过浏览器访问`http://localhost:15672`来监控和管理队列、交换机等。 **三、RabbitMQ API使用** 1. **客户端库**:RabbitMQ支持多种编程...
**RabbitMQ实战:高效部署分布式消息队列** 在当今的互联网应用开发中,分布式系统已经成为常态,而消息队列(Message Queue)作为其中的关键组件,对于系统的解耦、异步处理以及容错能力的提升起到了重要作用。...