RabbitMQ消息发送和接收(实例)
创始人
2024-04-04 15:23:29
0

消息发送:

1.首先启动rabbitmq

2.查看防火墙状态,如果是开启状态则需要关闭防火墙

3.通过浏览器访问rabbitmq控制台,ip+15672端口号 ,例如http://192.168.174.129:15672
登录时输入自己的此前设置的登录名和密码

4.打开idea,创建rabbitmq-product-java模块
导入依赖

com.rabbitmqamqp-client5.1.1

编写主程序代码

package com.it.rabbitmq;import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;import java.io.IOException;
import java.util.concurrent.TimeoutException;public class Product {public static void main(String[] args) {//创建连接工厂ConnectionFactory factory=new ConnectionFactory();//配置rabbitMQ的连接信息factory.setHost("192.168.174.129");factory.setPort(5672);factory.setUsername("root");factory.setPassword("123456");//定义连接Connection connection=null;//定义通道Channel channel=null;try {connection=factory.newConnection();//获取连接channel=connection.createChannel();//获取通道/*** 声明一个队列* 参数1:为队列名取任意值* 参数2:是否为持久化队列* 参数3:是否排外,如果排外则这个队列只允许一个消费者监听* 参数4:是否自动删除,如果为true则表示当前队列中没有消息,也没有消费者连接时就会自动删除这个队列。* 参数5:为队列的一些属性设置通常为null即可*/channel.queueDeclare("myQueue",true,false,false,null);//定义消息String message="我的RabbitMQ的测试消息";/*** 发送消息* 参数1:为交换机名称,这里为空字符串表示不使用交换机* 参数2:为队列名或RoutingKey,当指定了交换机名称以后这个值就是RoutingKey* 参数3:为消息的属性信息,通常为空即可* 参数4:为具体的消息数据的字节数组*/channel.basicPublish("","myQueue",null,message.getBytes("utf-8"));System.out.println("消息发送成功!");} catch (IOException e) {e.printStackTrace();} catch (TimeoutException e) {e.printStackTrace();}finally {if (channel!=null){try {channel.close();} catch (IOException e) {e.printStackTrace();} catch (TimeoutException e) {e.printStackTrace();}}if (connection!=null){try {connection.close();} catch (IOException e) {e.printStackTrace();}}}}}

运行代码

 

通过rabbitmq控制台查看添加的消息

点击该条消息进入消息详情页

点击消息出队

 

再次返回消息队列,此时消息队列已经没有了消息,消息已经模拟出队了

4.模拟连续向队列中放两次消息,这两条消息的队列名称相同,内容不同。

修改Idea消息的内容再向队列里发送一次消息

 运行一次

进入rabbitmq控制台

 修改Idea消息的内容再向队列里发送一次消息

 运行一次

进入rabbitmq控制台

 

 点击进入消息详细页

模拟从队列中取出消息,查看取出的消息内容

由此可知每次只能模拟取一条数据,取消息时符合队列先进先出的理念

 消息接收:

1.在idea中创建rabbitmq-consumer-java的模块
2.导入Maven依赖

com.rabbitmqamqp-client5.1.1

3.创建主函数

package com.it.rabbitmq;import com.rabbitmq.client.*;import java.io.IOException;
import java.util.concurrent.TimeoutException;public class Consumer {public static void main(String[] args) throws IOException, TimeoutException {ConnectionFactory factory = new ConnectionFactory();factory.setUsername("root");factory.setPassword("root");factory.setHost("192.168.222.128");//建立到代理服务器到连接Connection conn = factory.newConnection();//获得信道final Channel channel = conn.createChannel();//声明队列channel.queueDeclare("myQueue", true, false, false, null);//消费消息boolean autoAck = true;String consumerTag = "";//接收消息//参数1 队列名称//参数2 是否自动确认消息 true表示自动确认 false表示手动确认//参数3 为消息标签 用来区分不同的消费者这里暂时为""// 参数4 消费者回调方法用于编写处理消息的具体代码(例如打印或将消息写入数据库)//注意:使用了basicConsume方法以后,会启动一个线程持续的监听队列,如果队列中有信息的数据进入则会自动接收消息//因此不能关闭连接和通道对象channel.basicConsume("myQueue", autoAck, consumerTag, new DefaultConsumer(channel) {@Overridepublic void handleDelivery(String consumerTag,Envelope envelope,AMQP.BasicProperties properties,byte[] body) throws IOException {//获取消息数据String bodyStr = new String(body, "UTF-8");System.out.println("消费者--  "+bodyStr);}});
//            channel.close();
//            conn.close();}}

4.运行主函数

5.运行发送消息主函数


6.再次运行接收消息主函数


7.此时进入控制台查看队列,发现队列中的消息已经全部取出

注意:

1、Queue的消息只能被同一个消费者消费,如果没有消费监听队列那么消息会存放到队列中持久化保存,直到有消费者来消费这个消息,如果有消费者监听队列则立即消费发送到队列中的消息

2、Queue的消息可以保证每个消息都一定能被消费
3、消息接收编码时,不能关闭连接,一旦关闭就无法持续监听,照成功能失效。

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...