哈喽,大家好,我是木头左!
一、RabbitMQ简介
RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python、Ruby、.NET、Java、JMS、C、PHP、ActionScript、XMPP、STOMP等,支持AJAX。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。本文将详细介绍如何在Java项目中使用RabbitMQ。
二、环境搭建
2.1 安装Erlang
RabbitMQ是基于Erlang语言开发的,因此首先需要安装Erlang。请访问Erlang官网(https://www.erlang.org/downloads)下载并安装适合您操作系统的Erlang版本。
2.2 安装RabbitMQ
访问RabbitMQ官网(https://www.rabbitmq.com/download.html)下载并安装适合您操作系统的RabbitMQ版本。安装完成后,请确保RabbitMQ服务已启动。
三、Java项目中添加RabbitMQ依赖
在您的Java项目中,需要添加RabbitMQ Java客户端库的依赖。如果您使用的是Maven项目,请在pom.xml文件中添加以下依赖:
<dependency><groupId>com.rabbitmq</groupId><artifactId>amqp-client</artifactId><version>5.13.0</version></dependency>
如果您使用的是Gradle项目,请在build.gradle文件中添加以下依赖:
implementation 'com.rabbitmq:amqp-client:5.13.0'
四、创建RabbitMQ连接工厂和连接
4.1 创建连接工厂
连接工厂是RabbitMQ中用于创建和管理连接的类。以下是创建连接工厂的方法:
importcom.rabbitmq.client.ConnectionFactory;importcom.rabbitmq.client.Connection;importcom.rabbitmq.client.Channel;publicclassRabbitMQConnectionFactory{privatestaticfinalStringHOST="localhost";privatestaticfinalintPORT=5672;privatestaticfinalStringUSERNAME="guest";privatestaticfinalStringPASSWORD="guest";publicstaticConnectiongetConnection()throwsException{ConnectionFactory factory =newConnectionFactory();
factory.setHost(HOST);
factory.setPort(PORT);
factory.setUsername(USERNAME);
factory.setPassword(PASSWORD);return factory.newConnection();}}
4.2 创建连接和通道
连接是RabbitMQ中用于发送和接收消息的接口。以下是创建连接和通道的方法:
importcom.rabbitmq.client.Connection;importcom.rabbitmq.client.Channel;importcom.rabbitmq.client.ConnectionFactory;importjava.io.IOException;importjava.util.concurrent.TimeoutException;publicclassRabbitMQChannel{privatestaticfinalStringQUEUE_NAME="test_queue";privatestaticfinalStringEXCHANGE_NAME="test_exchange";privatestaticfinalStringROUTING_KEY="test_routing_key";privatestaticfinalintDELAY=5000;// 延迟时间,单位:毫秒privatestaticfinalbooleanDURABLE=true;// 是否持久化消息,默认为trueprivatestaticfinalbooleanAUTO_ACKNOWLEDGE=true;// 是否自动确认消息,默认为trueprivatestaticfinalbooleanNON_BLOCKING=false;// 是否阻塞模式,默认为false(非阻塞)privatestaticfinalintPRIORITY=5;// 优先级,范围:0-9(0-5为普通优先级,4-9为加权优先级)privatestaticfinalintTTL=10;// 消息过期时间,单位:秒(0表示不过期)privatestaticfinalbooleanREQUEUE=false;// 是否重新入队消息,默认为false(不重新入队)privatestaticfinalStringCUSTOM_CONSUMER_TAG="custom_consumer_tag";// 自定义消费者标签,用于过滤消息,可选参数,默认为空字符串(不过滤)privatestaticfinalStringCUSTOM_PREFIXED_ROUTING_KEY="custom_prefixed_routing_key";// 自定义前缀路由键,用于过滤消息,可选参数,默认为空字符串(不过滤)privatestaticfinalString[]CUSTOM_HEADERS=null;// 自定义头信息,用于过滤消息,可选参数,默认为null(不过滤)privatestaticfinalString[]CUSTOM_DETAILS=null;// 自定义消息属性,用于过滤消息,可选参数,默认为null(不过滤)privatestaticfinalString[]CUSTOM_APP_PROPERTIES=null;// 自定义应用属性,用于过滤消息,可选参数,默认为null(不过滤)privatestaticfinalString[]CUSTOM_SEGMENT=null;// 自定义分段器名称,用于过滤消息,可选参数,默认为null(不过滤)privatestaticfinalString[]CUSTOM_CONSUMER_GROUPS=null;// 自定义消费者组名称,用于过滤消息,可选参数,默认为null(不过滤)privatestaticfinalString[]CUSTOM_RECEIVE_HANDLERS=null;// 自定义接收处理器名称,用于过滤消息,可选参数,默认为null(不过滤)privatestaticfinalString[]CUSTOM_ACKNOWLEDGEMENT_HANDLERS=null;// 自定义确认处理器名称,用于过滤消息,可选参数,默认为null(不过滤)+> 我是木头左,感谢各位童鞋的点赞、收藏,我们下期更精彩!
版权归原作者 木头左 所有, 如有侵权,请联系我们删除。