热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

RabbitMQ入门案例

RabbitMQ入门案例Rabbit模式https:www.rabbitmq.comgetstarted.html实现步骤构建一个maven工程导入rabbitmq的依赖启动rab

RabbitMQ入门案例

Rabbit 模式


https://www.rabbitmq.com/getstarted.html



实现步骤



  • 构建一个 maven工程

  • 导入 rabbitmq的依赖

  • 启动 rabbitmq-server服务

  • 定义生产者

  • 定义消费者

  • 观察消息的在 rabbitmq-server服务中的进程


初步实现


前期准备


1.构建项目

1


2.导入依赖


com.rabbitmq
amqp-client
5.10.0


简单模型


4

在上图的模型中,有以下概念:



  1. 生产者,也就是要发送消息的程序

  2. 消费者:消息的接受者,会一直等待消息到来。

  3. 消息队列:图中红色部分。类似一个邮箱,可以缓存消息;生产者向其中投递消息,消费者从其中取出消息。



所有的中间件技术都是基于tcp/ip协议基础之上构建新型的协议规范,只不过rabbitmq遵循的是amqp



实现步骤:



  1. 创建连接工程

  2. 创建连接 connection

  3. 通过连接获取通道 Channel

  4. 通过通道创建交换机,声明队列,绑定关系,路由key,发送消息,和接收消息

  5. 准备消息内容

  6. 发送消息给队列 queue

  7. 关闭连接

  8. 关闭通道



生产者

public class Producer {
public static void main(String[] args) {
//1. 创建连接工程
ConnectionFactory cOnnectionFactory= new ConnectionFactory();
//这里要使用自己的IP地址
connectionFactory.setHost("192.168.57.129");
connectionFactory.setPort(5672);
connectionFactory.setUsername("admin");
connectionFactory.setPassword("admin");
connectionFactory.setVirtualHost("/");
Connection cOnnection= null;
Channel channel = null;
try {
//2. 创建连接 connection
cOnnection= connectionFactory.newConnection("生产者");
//3. 通过连接获取通道 Channel
channel = connection.createChannel();
//4. 通过通道创建交换机,声明队列,绑定关系,路由key,发送消息
String quequeName = "queuel";
/**
* @params1 队列的名称
* @params2 是否要持久化 durable-false
* @params3 排他性,是否是独占独立
* @params4 是否自动删除,随着最后一个消费者消息完毕以后是否把队列自动删除
* @params5 携带的附属参数
*/
channel.queueDeclare(quequeName,false,false,false,null);
//5. 准备消息内容
String message = "Hello,Consumer";
//6. 发送消息给队列 queue
channel.basicPublish("",quequeName,null,message.getBytes());
System.out.println("消息发送成功");
} catch (Exception e) {
e.printStackTrace();
}finally {
//7. 关闭连接
if (channel != null && channel.isOpen()){
try {
channel.close();
} catch (Exception e) {
e.printStackTrace();
}
}
//8. 关闭通道
if (connection != null && connection.isOpen()){
try {
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}

消费者

public class Consumer {
public static void main(String[] args) {
//1. 创建连接工程
ConnectionFactory cOnnectionFactory= new ConnectionFactory();
//这里要使用自己的IP地址
connectionFactory.setHost("192.168.57.129");
connectionFactory.setPort(5672);
connectionFactory.setUsername("admin");
connectionFactory.setPassword("admin");
connectionFactory.setVirtualHost("/");
Connection cOnnection= null;
Channel channel = null;
try {
//2. 创建连接 connection
cOnnection= connectionFactory.newConnection("消费者");
//3. 通过连接获取通道 Channel
channel = connection.createChannel();
//4. 通过通道创建交换机,声明队列,绑定关系,路由key,发送消息,和接收消息
String quequeName = "queue1";
channel.queueDeclare(quequeName,false,false,false,null);
//5.监听消息
DefaultConsumer cOnsumer= new DefaultConsumer(channel){
/*
consumerTag:消息者标签,channel.basicConsume可以指定
envelope:消息包内容,可从中获取消息id,消息routing key,交换机,消息和重装标记(收到消息失败后是否需要重新发送)
properties:消息属性
body;消息
*/
@Override
public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
//路由key
System.out.println("路由key为:"+ envelope.getRoutingKey());
//交换机
System.out.println("交换机为:"+ envelope.getExchange());
//消息id
System.out.println("消息id为:"+ envelope.getDeliveryTag());
//收到的消息
System.out.println("接收到的消息:"+ new String(body,"UTF-8"));
System.out.println("");
System.out.println("======================================================");
System.out.println("");
}
};
channel.basicConsume("queue1", true, consumer);
} catch (Exception e) {
e.printStackTrace();
}finally {
//6. 不关闭资源,一直监听
}
}
}

5


5

AMQP


概念介绍


AMQP 一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。

AMQP是一个二进制协议,拥有一些现代化特点:多信道协商式异步安全扩平台中立高效

RabbitMQ 是 AMQP协议 的 Erlang的实现。












































概念说明
连接 Connection一个网络连接,例如:TCP/IP套接字连接。
会话 Session端点之间的命名对话。在一个会话上下文中,保证“恰好传递一次”。
信道 Channel多路复用连接中的一条独立的双向数据流通道。为会话提供物理传输介质。
客户端 ClientAMQP连接或者会话的发起者。AMQP是非对称的,客户端生产和消费消息,服务器存储和路由这些消息。
服务节点Broker消息中间件的服务节点。一般情况下可以将一个RabbitMQ Broker看作一台RabbitMQ 服务器。
端点AMQP对话的任意一方。一个AMQP连接包括两个端点(一个是客户端,一个是服务器)。
消费者 Consumer一个从消息队列里请求消息的客户端程序。
生产者 Producer一个向交换机发布消息的客户端应用程序。

RabbitMQ运转流程


入门案例 为例



生产者发送消息



  1. 生产者创建连接(Connection),开启一个信道(Channel),连接到RabbitMQ Broker;

  2. 声明队列、设置属性;如是否排它,是否持久化,是否自动删除;

  3. 将路由键(空字符串)与队列绑定起来;

  4. 发送消息至RabbitMQ Broker;

  5. 关闭信道;

  6. 关闭连接;


消费者接收消息



  1. 消费者创建连接(Connection),开启一个信道(Channel),连接到RabbitMQ Broker

  2. 向Broker 请求消费相应队列中的消息,设置相应的回调函数;

  3. 等待Broker回应闭关投递响应队列中的消息,消费者接收消息;

  4. 确认(ack,自动确认)接收到的消息;

  5. RabbitMQ从队列中删除相应已经被确认的消息;

  6. 关闭信道;

  7. 关闭连接;


生产者流转过程解析



  1. 客户端与代理服务器Broker建立连接。调用 newConnection() 方法 , 会进一步封装 Protocol Header 0-9-1 的报文头发送给 Broker ,以此通知Broker 本次交互采用的是 AMQP 0-9-1 协议,紧接着 Broker 返回 Connection.Start 来建立连接,在连接的过程中涉及 Connection.Start/.Start-OKConnection.Tune/.Tune-OkConnection.Open/ .Open-Ok 这6 个命令的交互。

  2. 客户端调用 connection.createChannel 方法。此方法开启信道,其包装的 channel.open 命令发送给 Broker , 等待 channel.basicPublish 方法,对应的AMQP命令为 Basic.Publish , 这个命令包含了content Headercontent Body() 。content Header 包含了消息体的属性,例如:投递模式,优先级等,content Body 包含了消息体本身。

  3. 客户端发送完消息需要关闭资源时,涉及到Channel.Close和Channl.Close-OkConnetion.Close和Connection.Close-Ok的命令交互。

6


消费者流转过程解析



  1. 消费者客户端与代理服务器Broker建立连接。会调用 newConnection() 方法,这个方法会进一步封装 Protocol Header 0-9-1 的报文头发送给Broker ,以此通知Broker 本次交互采用的是 AMQP 0-9-1 协议,紧接着Broker 返回Connection.Start 来建立连接,在连接的过程中涉及Connection.Start/.Start-OK 、Connection.Tune/.Tune-Ok ,Connection.Open/ .Open-Ok 这6 个命令的交互。

  2. 消费者客户端调用connection.createChannel方法。和生产者客户端一样,协议涉及Channel . Open/Open-Ok命令。

  3. 在真正消费之前,消费者客户端需要向Broker 发送Basic.Consume 命令(即调用channel.basicConsume 方法〉将Channel 置为接收模式,之后Broker 回执 Basic . Consume - Ok 以告诉消费者客户端准备好消费消息。

  4. Broker 向消费者客户端推送(Push) 消息,即 Basic.Deliver 命令,这个命令和 Basic.Publish 命令一样会携带 Content Header 和Content Body。

  5. 消费者接收到消息并正确消费之后,向Broker 发送确认,即 Basic.Ack 命令。

  6. 客户端发送完消息需要关闭资源时,涉及到 Channel.Close和Channl.Close-Ok 与Connetion.Close和Connection.Close-Ok 的命令交互。

7


个人博客为:

MoYu's HomePage




推荐阅读
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
author-avatar
活宝贝aaaaaaaaaaaaa
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有