RabbitMQ学习总结(2)-API的使用
1. 引用依赖
<dependency>
<groupId>com.rabbitmq</groupId>
<artifactId>amqp-client</artifactId>
<version>5.1.2</version>
</dependency>
2. 连接MQ
public static Connection getConnection() throws Exception {
// 创建一个连接工厂
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("127.0.0.11"); // 设置rabbitmq服务器地址
factory.setPort(5672);
factory.setUsername("***");
factory.setPassword("***");
factory.setVirtualHost("testhost"); // 在后台配置的虚拟地址,类似于库,默认是/
return factory.newConnection();
}
3. 发送消息
实现方式1:最基础的方法消息方法,只需要指定队列,不填写交换机名称会使用MQ默认的。
public static void sendMessage(String message) throws Exception {
// 创建连接
Connection connection = ConnectionUtil.getConnection();
// 创建通道
Channel channel = connection.createChannel();
// 创建队列
// 参数1: ConnectionUtil.QUEUE_NAME,队列名称
// 参数2:true 队列是否需要持久化(队列持久化和消息持久化是两回事)
// 参数3:false 是否(排他队列)单一队列,这里表示此队列是否只给这个连接使用
// 参数4:false 是否自动删除,表示在没有人使用时是否自动删除
// 参数5:null 是个Map类型,可以传一些队列参数
channel.queueDeclare(ConnectionUtil.QUEUE_NAME,true,false,false,null);
// 参数1:交换机名称,为空时,使用默认交换机AMQP default
// 参数2:队列名称,在绑定队列之后,会把队列名称作为交换机的路由键使用
// 参数3:。。
// 参数4:消息内容,Byte类型
channel.basicPublish("", ConnectionUtil.QUEUE_NAME, null, message.getBytes());
// 关闭通道
channel.close();
// 关闭连接
connection.close();
}
实现方式2:指定交换机类型fanout
public static void sendMessage(String message) throws Exception {
// 创建连接
Connection connection = ConnectionUtil.getConnection();
// 创建通道
Channel channel = connection.createChannel();
// 删除交换机,因为之前测试可能申请过这个名字的交换机,更改类型会报错
channel.exchangeDelete("exchangeTest");
// 创建交换机exchange
// 参数1:交换机名称
// 参数2:交换机类型
channel.exchangeDeclare("exchangeTest", BuiltinExchangeType.FANOUT);
// 交换机与队列绑定
// 参数1:队列名称
// 参数2:交换机名称
// 参数3:routingKey路由键,fanout类型交换机是不需要路由键的
channel.queueBind("queue1", "exchangeTest", "");
// 发送消息
// 参数1:交换机名称,为空时,使用默认交换机AMQP default
// 参数2:routingKey路由键,fanout类型交换机是不需要路由键的
// 参数3:。。
// 参数4:消息内容,Byte类型
channel.basicPublish("exchangeTest", "", null, message.getBytes());
// 关闭通道
channel.close();
// 关闭连接
connection.close();
}
实现方式3:指定交换机类型direct,其他代码跟上面一样,只是BuiltinExchangeType类型不同,绑定队列时需要填写routingKey
channel.exchangeDeclare("exchangeTest2", BuiltinExchangeType.DIRECT);
// 交换机与队列绑定
// 参数1:队列名称
// 参数2:交换机名称
// 参数3:绑定队列的routingKey路由键,direct,routingKey是必填的
channel.queueBind("queue1", "exchangeTest2", "info.user");
channel.queueBind("queue2", "exchangeTest2", "error.user");
实现方式4:执行交换机类型topic,routingKey是模糊匹配的
channel.exchangeDeclare("exchangeTest3", BuiltinExchangeType.TOPIC);
// 交换机与队列绑定
// 匹配debug开头,user结尾,中间随机的路由键
channel.queueBind("queue1", "exchangeTest3", "debug.*.user");
// 匹配所有error开头的所有路由键
channel.queueBind("queue2", "exchangeTest3", "error.#");
// 匹配中断是email,前后段随机的路由键
channel.queueBind("queue3", "exchangeTest3", "*.email.*");
2.4 接收消息
默认接收方式
public static void getMessage() throws Exception {
Connection connection = ConnectionUtil.getConnection();
Channel channel = connection.createChannel();
// 第一次连接时还要确认是否创建通道,没有的话使用channel.queueDeclare()方法创建
// 定义消费者,传入channel
DefaultConsumer consumer = new DefaultConsumer(channel){
/**
* 服务的监听器
* @param consumerTag 消费者标识
* @param envelope 消息详细信息:包括交换机,路由键,消息标识
* @param properties 消息配置
* @param body 消息内容
*/
@Override
public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
// 打印消息
System.out.println(new String(body, "UTF-8"));
// 手动确认消息
// 参数1:消费的唯一标识,从envelope内获取
// 参数2:声明是否批量确认
channel.basicAck(envelope.getDeliveryTag(), false);
}
};
// 开始消费。指定消费队列的名称,绑定消费者
// 参数1-queue:消费通道名称
// 参数2-autoAck:自动消息确认开关,默认是false,false状态需要手动确认消费消息
// 参数3-callback:消费对象
channel.basicConsume("queue1", false, consumer); // 消费者是不需要关闭连接的,因为要一直监听
}
RabbitMQ学习总结(2)-API的使用的更多相关文章
- Redis总结(五)缓存雪崩和缓存穿透等问题 Web API系列(三)统一异常处理 C#总结(一)AutoResetEvent的使用介绍(用AutoResetEvent实现同步) C#总结(二)事件Event 介绍总结 C#总结(三)DataGridView增加全选列 Web API系列(二)接口安全和参数校验 RabbitMQ学习系列(六): RabbitMQ 高可用集群
Redis总结(五)缓存雪崩和缓存穿透等问题 前面讲过一些redis 缓存的使用和数据持久化.感兴趣的朋友可以看看之前的文章,http://www.cnblogs.com/zhangweizhon ...
- RabbitMQ学习系列(三): C# 如何使用 RabbitMQ
上一篇已经讲了Rabbitmq如何在Windows平台安装,还不了解如何安装的朋友,请看我前面几篇文章:RabbitMQ学习系列一:windows下安装RabbitMQ服务 , 今天就来聊聊 C# 实 ...
- RabbitMQ学习总结 第三篇:工作队列Work Queue
目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...
- RabbitMQ学习总结 第二篇:快速入门HelloWorld
目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...
- RabbitMQ学习笔记1-hello world
安装过程略过,一搜一大把. rabbitmq管理控制台:http://localhost:15672/ 默认账户:guest/guest RabbitMQ默认监听端口:5672 JAVA API地 ...
- RabbitMQ学习在windows下安装配置
RabbitMQ学习一. 在windows下安装配置 1.下载并安装erlang,http://www.erlang.org/download.html,最新版是R15B01(5.9.1).由于我机器 ...
- RabbitMQ学习系列三-C#代码接收处理消息
RabbitMQ学习系列三:.net 环境下 C#代码订阅 RabbitMQ 消息并处理 http://www.80iter.com/blog/1438251320680361 http://www. ...
- RabbitMQ学习系列二-C#代码发送消息
RabbitMQ学习系列二:.net 环境下 C#代码使用 RabbitMQ 消息队列 http://www.80iter.com/blog/1437455520862503 上一篇已经讲了Rabbi ...
- RabbitMQ学习系列三:.net 环境下 C#代码订阅 RabbitMQ 消息并处理
上一篇已经讲了Rabbitmq如何在Windows平台安装 不懂请移步: RabbitMQ学习系列二:.net 环境下 C#代码使用 RabbitMQ 消息队列 一.理论 .net环境下,C#代码订阅 ...
随机推荐
- 小程序报错 parameter.content should be String instead of Undefined;
自己遇到了两种情况会导致这个问题 1.参数名写错未定义,然后赋值的时候值为undefined 2.服务端返回的值错误,返回的值为空,导致赋值时报错 解决方法: 1.检查参数名,如不是全局变量的应在da ...
- day33 网络编程(下)
目录 上节课回顾: 一.传输层 二.应用层 三.socket 四.如何获取目标ip地址 五.网络通信的流程 上节课回顾: 通过ip地址如何找到另外一台设备 ip地址分为子网部分和主机部分 我们要和其他 ...
- 《Spring全局异常处理》从零掌握@ControllerAdvice注解
一.开门见山 在前后端分离框架的大趋势下,前后端基本的职责已经确定. 前端主要负责界面的处理以及基本的判空检验.数据来源则通过vue调用后端发布的接口. 后端的原型还是mvc的模式: controll ...
- three.js 几何体(三)
上一篇介绍了几何体的构造体参数,这篇郭先生就接着上一篇说. 1. ExtrudeGeometry挤压几何体 挤压几何体允许我们从一条形状路径中,挤压出一个Geometry.ExtrudeGeometr ...
- Go的100天之旅-02基本语法
基本语法 Go关键字 下面是Go的25个关键字: break default func interface select case defer go map struct chan else goto ...
- day8 python 列表,元组,集合,字典的操作及方法 和 深浅拷贝
2.2 list的方法 # 增 list.append() # 追加 list.insert() # 指定索引前增加 list.extend() # 迭代追加(可迭代对象,打散追加) # 删 list ...
- 从连接器组件看Tomcat的线程模型——BIO模式
在高版本的Tomcat中,默认的模式都是使用NIO模式,在Tomcat 9中,BIO模式的实现Http11Protocol甚至都已经被删除了.但是了解BIO的工作机制以及其优缺点对学习其他模式有有帮助 ...
- 写给.NET开发者的Python教程(二):基本类型和变量
从本文开始,我们就要正式了解Python的语法特性了,这章主要介绍基本类型和变量,开始之前先介绍下Python中的标准输入输出. 标准输入输出 前文举过TwoSum问题的例子,但是没有讲到标准输入输出 ...
- Springboot启动扩展点超详细总结,再也不怕面试官问了
1.背景 Spring的核心思想就是容器,当容器refresh的时候,外部看上去风平浪静,其实内部则是一片惊涛骇浪,汪洋一片.Springboot更是封装了Spring,遵循约定大于配置,加上自动装配 ...
- UVA1104 芯片难题 Chips Challenge
题目链接 题意 网格上放点,有些强制放,有些不能放,有些可以放可以不放.要求: 第 \(i\) 行的点数 = 第 \(i\) 列的点数 每一行每一列的点数不超过总点数的 \(k\) 倍(\(k\) 已 ...