RabbitMQ入門(一) —— 基本概念

RabbitMQ都安裝了好一陣子,但一直沒有時間去學習。今天正式開始進入RabbitMQ的學習,通過博文把自己的一些學習心得記錄下來,以備以後查閱。由於自己也是從零開始入門,所以這裏不會涉及到很深的理論知識,畢竟先要學會如何使用。關於RabbitMQ是什麼,有哪些用處,大家可以自行Google。


首先,我們來看一張RabbitMQ最簡單的流程圖,也是我們平時使用最多的幾個組件。

wKioL1cLjfSiLxMhAADu0xTie_w054.pngexchange:交換器。RabbitMQ裏面有很多交換器,我們也可以創建自己的交換器。當我們向RabbitMQ發送一條消息時,我們必須指定對應的exchange,然後這條消息就會到達我們指定的exchange。

queue:隊列。RabbitMQ是一款消息服務器,也稱消息隊列。我們發送給RabbitMQ的消息最後都會到達各種queue,並且存儲在其中(如果路由找不到相應的queue則數據會丟失),等待消費者來取。

routing key:路由鍵。用來建立queue和exchange之間的對應關係。當消息到達exchange之後,exchange怎麼知道應該把這個消息放到哪個queue呢?其實不同類型的exchange會根據不同的匹配規則去匹配綁定在它身上的routing key,找到了就把這個消息放到routing key對應的queue裏。

這三個組件是我們以後用得最多,也是RabbitMQ最基礎的組件。在後面的文章中還會有更詳細說明。




下面我們來看RabbitMQ官方給我們提供的一個簡單的producer-consumer例子,我簡單的修改了下,通過這個例子我們可以瞭解RabbitMQ的基本用法。

package com.jaeger.helloworld;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

import org.junit.Test;

import com.rabbitmq.client.AMQP;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Consumer;
import com.rabbitmq.client.DefaultConsumer;
import com.rabbitmq.client.Envelope;

public class HelloWorldTest {
	private static final String QUEUE_NAME = "hello_queue";
	private static final String HOST = "172.19.64.21";
	private static final String USER = "jaeger";
	private static final String PASSWORD = "root";
	private static final int PORT = 5672;

	@Test
	public void send() {
		ConnectionFactory connectionFactory = new ConnectionFactory();
		connectionFactory.setHost(HOST);
		connectionFactory.setUsername(USER);
		connectionFactory.setPassword(PASSWORD);
		connectionFactory.setPort(PORT);

		try {
			Connection connection = connectionFactory.newConnection();
			Channel channel = connection.createChannel();
			channel.queueDeclare(QUEUE_NAME, false, false, false, null);
			String message = "Hello 世界!";
			channel.basicPublish("", QUEUE_NAME, null, message.getBytes("utf-8"));
			System.out.println("Sent '" + message + "'");
			channel.close();
			connection.close();
		} catch (IOException e) {
			e.printStackTrace();
		} catch (TimeoutException e) {
			e.printStackTrace();
		}
	}

	@Test
	public void receive() throws InterruptedException {
		ConnectionFactory connectionFactory = new ConnectionFactory();
		connectionFactory.setHost(HOST);
		connectionFactory.setUsername(USER);
		connectionFactory.setPassword(PASSWORD);
		connectionFactory.setPort(PORT);
		try {
			Connection connection = connectionFactory.newConnection();
			Channel channel = connection.createChannel();
			channel.queueDeclare(QUEUE_NAME, false, false, false, null);
			Consumer consumer = new DefaultConsumer(channel) {
				@Override
				public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties,
						byte[] body) throws IOException {
					String message = new String(body, "UTF-8");
					System.out.println("Received '" + message + "'");
				}
			};
			channel.basicConsume(QUEUE_NAME, true, consumer);
			Thread.sleep(1000);  //A
		} catch (IOException e) {
			e.printStackTrace();
		} catch (TimeoutException e) {
			e.printStackTrace();
		}
	}
}

我們先運行send方法,向RabbitMQ裏添加一條消息,然後查看下RabbitMQ後臺,可以看到這條消息已經添加進去了:

wKiom1cLmu3QxrOHAAAgNHQh5B8791.png

我們再運行receive方法,在A處我們讓主線程睡眠下,讓handleDelivery這個回調方法有機會執行,不然主線程直接結束了,那回調方法都沒機會執行。在實際應用中一般consumer都是單開線程一直監聽對應queue。下面是結果:

wKiom1cLnJjAVlBqAAAmNSuJaIY679.png

wKioL1cLnUyBx8NTAAAdsF4y_CQ425.png

這個例子只是讓我們瞭解下RabbitMQ的基本用法,其中有很多概念這裏並沒有說明,我在後面的文章中會有講解。大家如果着急,可以自己先Google。t_0007.gif

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章