RabbitMQ学习入门笔记
来源:互联网 发布:网络流行欧美歌曲 编辑:程序博客网 时间:2024/06/05 20:57
RabbitMQ是什么?
AMQP
即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然。
AMQP的主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。
RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python、Ruby、.NET、Java、JMS、C、PHP、ActionScript、XMPP、STOMP等,支持AJAX。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。
ConnectionFactory、Connection、Channel
ConnectionFactory、Connection、Channel都是RabbitMQ对外提供的API中最基本的对象。Connection是RabbitMQ的socket链接,它封装了socket协议相关部分逻辑。ConnectionFactory为Connection的制造工厂。
Channel是我们与RabbitMQ打交道的最重要的一个接口,我们大部分的业务操作是在Channel这个接口中完成的,包括定义Queue、定义Exchange、绑定Queue与Exchange、发布消息等。
http://www.rabbitmq.com/tutorials/tutorial-one-java.html
- 生产者(producer):发送消息的程序;
- 消费者(consumer):接收消息的程序;
- 队列(queue):保存消息的盒子,类似一个缓冲,是生产者和发消费者交换数据的中介。
怎样安装使用RabbitMQ?
RabbitMQ是基于erlang开发的,首先需要安装erlang,到官网下载www.erlang.org/。
由于官网经常访问不了,这里我提供自己百度云链接http://pan.baidu.com/s/1eRiWfWu。
Rabbit下载地址http://www.rabbitmq.com/download.html。
安装后启动Rabbit-server,”D:\Program Files\RabbitMQ Server\rabbitmq_server-3.5.6\sbin\rabbitmq-service.bat” start。
记住在window系统中必须要以管理员身份启动,否则会报错
“Hello world”的入门
- 1.创建连接工厂ConnectionFactory,设置RabbitMQ的服务地址
- 2.创建连接Connection
- 3.创建频道Chanel
- 4.创建队列queue
- 5.发送消息或者接收消息
- 6.关闭资源
Sending
package example.ydoing.rabbitmq;import java.io.IOException;import java.util.concurrent.TimeoutException;import com.rabbitmq.client.ConnectionFactory;import com.rabbitmq.client.Connection;import com.rabbitmq.client.Channel;public class Send { private final static String QUEUE_NAME = "hello"; public static void main(String[] args) throws IOException, TimeoutException{ /** * 创建连接连接到MabbitMQ */ ConnectionFactory factory = new ConnectionFactory(); //设置RabbitMQ所在主机ip或者主机名 factory.setHost("localhost"); //创建一个连接 Connection connection = factory.newConnection(); //创建一个频道 Channel channel = connection.createChannel(); //指定一个队列 channel.queueDeclare(QUEUE_NAME, false, false, false, null); //发送的消息 String message = "hello world!"; //往队列中发出一条消息 channel.basicPublish("", QUEUE_NAME, null, message.getBytes()); System.out.println(" [x] Sent '" + message + "'"); //关闭频道和连接 channel.close(); connection.close(); }}
Receiving
package example.ydoing.rabbitmq;import java.io.IOException;import java.util.concurrent.TimeoutException;import com.rabbitmq.client.ConnectionFactory;import com.rabbitmq.client.Connection;import com.rabbitmq.client.Channel;import com.rabbitmq.client.ConsumerCancelledException;import com.rabbitmq.client.QueueingConsumer;import com.rabbitmq.client.ShutdownSignalException;public class Recv { private final static String QUEUE_NAME = "hello"; public static void main(String[] args) throws IOException, TimeoutException, ShutdownSignalException, ConsumerCancelledException, InterruptedException { ConnectionFactory factory = new ConnectionFactory(); factory.setHost("localhost"); Connection connection = factory.newConnection(); Channel channel = connection.createChannel(); channel.queueDeclare(QUEUE_NAME, false, false, false, null); System.out.println(" [*] Waiting for messages. To exit press CTRL+C"); // 创建队列消费者 QueueingConsumer consumer = new QueueingConsumer(channel); // 指定消费队列 channel.basicConsume(QUEUE_NAME, true, consumer); while (true) { // nextDelivery是一个阻塞方法(内部实现其实是阻塞队列的take方法) QueueingConsumer.Delivery delivery = consumer.nextDelivery(); String message = new String(delivery.getBody()); System.out.println(" [x] Received '" + message + "'"); } }}
- RabbitMQ学习入门笔记
- RabbitMQ 学习笔记
- rabbitmq学习笔记一
- RabbitMQ学习笔记
- Rabbitmq学习笔记
- RabbitMQ学习笔记
- rabbitmq学习笔记
- RabbitMQ学习笔记
- RabbitMQ学习笔记
- RabbitMQ 学习笔记
- rabbitMq学习笔记(未完)
- RabbitMQ学习笔记
- rabbitmq学习笔记
- rabbitmq学习笔记
- RabbitMQ学习笔记
- RabbitMQ学习笔记
- rabbitMQ学习笔记
- RabbitMQ学习笔记
- zzulioj 1827: 石锅全拌 (线段树求区间和)
- Objective-C语言——实例方法与类方法之间互相调用
- jqurey.fullpage.js解读
- linux 下svn安装配置
- Python模块学习系列(4)----matplotlib
- RabbitMQ学习入门笔记
- pdf2html 手动编译,解决segmentation fault错误
- hdoj--5563--Clarke and five-pointed star(简单几何)
- 二维向量vector の 邪恶的多维数组 (一)
- Python快速入门笔记
- JavaScript函数-带参数的函数、带返回值的参数
- 黑马程序员——Java---类继承-覆盖-重载
- 利用org.json处理获得的json数据
- online_judge_1038