掃二維碼與項(xiàng)目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
大家好,我是指北君。

創(chuàng)新互聯(lián)公司-成都網(wǎng)站建設(shè)公司,專注成都做網(wǎng)站、成都網(wǎng)站建設(shè)、網(wǎng)站營銷推廣,域名與空間,網(wǎng)頁空間,綿陽服務(wù)器托管有關(guān)企業(yè)網(wǎng)站制作方案、改版、費(fèi)用等問題,請聯(lián)系創(chuàng)新互聯(lián)公司。
在工作中經(jīng)常會用到消息隊(duì)列處理各種問題,今天指北君帶領(lǐng)大家來學(xué)一個很常用到的技術(shù)-RabbitMQ;接下來還會有關(guān)于RabbitMQ的系列教程。
隊(duì)列:一種數(shù)據(jù)結(jié)構(gòu),先進(jìn)先出。
消息隊(duì)列:簡單的說就是用來進(jìn)行消息傳輸?shù)年?duì)列。
消息中間件:簡單的說就是用來傳輸消息的中間載體,就是將你的信息發(fā)送到接受方,它并不關(guān)心發(fā)送的數(shù)據(jù)是什么。RabbitMQ就是一個消息中間件。
首先,安裝RabbitMQ,可直接使用docker安裝一個。
docker 地址:https://hub.docker.com/_/rabbitmq/tags
# 拉取鏡像
docker pull rabbitmq:management
# 啟動容器
docker run -id --hostname my-rabbit \
--name rabbitmq \
-p 15672:15672 \
-p 5672:5672 \
-e RABBITMQ_DEFAULT_USER=admin \
-e RABBITMQ_DEFAULT_PASS=admin \
rabbitmq:management
然后在網(wǎng)頁訪問:http://服務(wù)器的ip:15672,輸入賬號密碼。記得開放端口
看到此頁面代表安裝成功
準(zhǔn)備就緒,先寫個Hello World
org.springframework.boot
spring-boot-starter-amqp
public class ConnectionUtils {
public static Connection getConnection(){
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("1.15.88.28");
factory.setPort(5672);
factory.setUsername("admin");
factory.setPassword("admin");
factory.setVirtualHost("/");
try {
return factory.newConnection();
} catch (IOException | TimeoutException e) {
e.printStackTrace();
}
return null;
}
}public class Producer {
// 聲明隊(duì)列的名字
private static final String QUEUE_NAME = "queue_helloworld_1";
public static void main(String[] args) throws IOException, TimeoutException {
// 1. 獲取連接
Connection connection = ConnectionUtils.getConnection();
// 2. 創(chuàng)建數(shù)據(jù)傳輸通道
Channel channel = connection.createChannel();
// 3. 聲明隊(duì)列
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
// 4. 發(fā)送數(shù)據(jù)到隊(duì)列
channel.basicPublish("", QUEUE_NAME, MessageProperties.PERSISTENT_TEXT_PLAIN, "第一個隊(duì)列消息...".getBytes());
// 5. 關(guān)閉通道
channel.close();
// 6. 關(guān)閉連接
connection.close();
}
}public class Consumer {
// 聲明隊(duì)列的名字
private static final String QUEUE_NAME = "queue_helloworld_1";
public static void main(String[] args) throws IOException, TimeoutException {
// 1. 獲取連接
Connection connection = ConnectionUtils.getConnection();
// 2. 創(chuàng)建通道
Channel channel = connection.createChannel();
// 3. 聲明隊(duì)列
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
// 4. 聲明消費(fèi)者
DefaultConsumer defaultConsumer = new DefaultConsumer(channel) {
@Override
public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
System.out.println("接收到的消息是:" + new String(body));
channel.basicAck(envelope.getDeliveryTag(), false);
}
};
// 5. 綁定消費(fèi)者
channel.basicConsume(QUEUE_NAME, false, defaultConsumer);
}
}本文到這里就結(jié)束了,簡單介紹了一下RabbitMQ是什么,以及RabbitMQ的安裝。

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流