成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

手把手教你從 0 到 1 搭建一套 RocketMQ 集群

開發 新聞
這篇文章主要講述了 RocketMQ 集群的搭建,希望能對大家理解 RocketMQ 有所幫助。

大家好,我是君哥。今天來分享怎樣搭建 RocketMQ 集群。

本文搭建集群使用的環境是 2 個云主機,架構如下:

圖片

在 47.xx.xx.xx 和 39.xx.xx.xx 上分別部署一個 Name Server 和 Broker 主節點,這里不搭建從節點。也就是官網介紹的 2m-noslave 構建模式。

注意:官網有三種配置模式:2m-2s-sync、2m-2s-async、2m-noslave。這三種配置都是使用異步刷盤策略:ASYNC_FLUSH。

集群搭建成功后,Broker 會向 Name Server 注冊 Topic 路由信息,Producer 和 Consumer 則從 Name Server 獲取路由信息,然后 Producer 根據路由信息向 Broker 發送消息,Consumer 則根據路由信息從 Broker 拉取消息。

1 準備工作

要安裝 RocketMQ,首先需要在云主機上安裝 Java 環境,Maven 環境。這里就不做詳細介紹了。

Java 和 Maven 環境安裝好以后,從官網下載最新版本,地址如下:

https://dlcdn.apache.org/rocketmq/4.9.4/rocketmq-all-4.9.4-bin-release.zip

下載完成后,進行解壓和編譯,執行如下命令:

> unzip rocketmq-all-4.9.4-source-release.zip
> cd rocketmq-all-4.9.4-source-release/
> mvn -Prelease-all -DskipTests clean install -U
> cd distribution/target/rocketmq-4.9.4/rocketmq-4.9.4

看到下圖輸出時,編譯成功:

圖片

2 啟動

2.1 啟動 Name Server

因為我的云主機內存比較小,而 RocketMQ 默認啟動 Name Server 需要的 JVM 堆內存默認是 4g,所以需要修改默認堆內存。修改文件為:

rocketmq-all-4.9.4-source-release/distribution/target/rocketmq-4.9.4/rocketmq-4.9.4/bin/runserver.sh

修改后的配置如下:

JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"

修改完成后,執行下面命令:

nohup sh bin/mqnamesrv &

啟動成功后,nohup.out 文件中打印如下日志:

The Name Server boot success. serializeType=JSON

搭建好一臺機器后,用同樣的方式搭建第二臺機器。

2.2 啟動 Broker

同樣,RocketMQ 啟動 Broker 需要的 JVM 堆內存默認是 8g,所以需要修改堆內存。修改文件為:

rocketmq-all-4.9.4-source-release/distribution/target/rocketmq-4.9.4/rocketmq-4.9.4/bin/runbroker.sh

修改后的配置如下:

JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx512m"

創建 conf.properties 文件,內容如下:

brokerClusterName = MyTestCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
namesrvAddr=127.0.0.1:9876;47.xx.xx.xx:9876

配置好后,啟動 broker-a 節點,啟動 命令如下:

nohup bash bin/mqbroker -c conf/broker.properties &

Broker 啟動成功后,Name Server 的日志如下圖:

圖片

用同樣的方式啟動 broker-b,conf.properties 文件配置如下:

#集群名稱
brokerClusterName = MyTestCluster
#broker名稱
brokerName = broker-b
brokerId = 0
#刪除消息存儲過期文件的時間為凌晨4點
deleteWhen = 04
#未發生更新的消息存儲文件的保留時長為48小時,48小時后過期,將會被刪除
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
namesrvAddr=127.0.0.1:9876;xx.xx.xx.xx:9876

啟動成功后,執行 mqadmin 命令查看集群信息:

[root@rocketmq-4.9.4]# ./bin/mqadmin topicList -n 127.0.0.1:9876
MyTestCluster
RMQ_SYS_TRANS_HALF_TOPIC
BenchmarkTest
OFFSET_MOVED_EVENT
iZ8vbfyc7hfzygtpgapblyZ
TBW102
SELF_TEST_TOPIC
DefaultCluster
iZ2ze4m2ri7irk6au5mbfgZ
SCHEDULE_TOPIC_XXXX
DefaultCluster_REPLY_TOPIC
broker-b
broker-a
MyTestCluster_REPLY_TOPIC

注意:執行上面命令需要修改 bin/tools.sh 中的 JVM 參數,配置如下:

JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m"

3 dashboard

3.1 安裝

安裝 dashboard,需要編譯源代碼,源碼 github 地址如下:

https://github.com/apache/rocketmq-dashboard

下載之后,修改 application.yml 參數,我這里只修改了 Name Server 地址:

rocketmq:
config:
namesrvAddrs:
- 127.0.0.1:9876
- 47.xx.xx.xx:9876

然后執行 Maven 打包命令,打出 jar 包:

mvn clean package -Dmaven.test.skip=true

打好 jar 包后上傳到服務器,執行下面命令啟動:

java -jar rocketmq-dashboard-1.0.1-SNAPSHOT.jar

啟動成功后,輸出下圖的日志:

圖片

3.2 測試

瀏覽器輸入 http://39.xx.xx.xx:8080/ 界面如下:

圖片

使用下面命令創建一個 Topic,名字叫 MyTestTopic:

sh bin/mqadmin updateTopic -n 127.0.0.1:9876\;47.92.71.246:9876  -c MyTestCluster  -t MyTestTopic

這是可以在界面上看到創建的 Topic,如下圖:

圖片

使用命令發送一條消息:

[root@rocketmq-4.9.4]# sh bin/mqadmin sendMessage -n 127.0.0.1:9876 -t MyTestTopic -p 'hello test message'
#Broker Name #QID #Send Result #MsgId
broker-a 1 SEND_OK 7F000001D3C3339097527B50D1740000

在界面上查看消息,如下圖:

圖片

4 總結

這篇文章主要講述了 RocketMQ 集群的搭建,希望能對大家理解 RocketMQ 有所幫助。

責任編輯:張燕妮 來源: 君哥聊技術
相關推薦

2019-10-29 15:46:07

區塊鏈區塊鏈技術

2024-10-21 08:01:49

私服倉庫Maven

2024-05-30 10:30:39

2018-03-05 11:10:12

2022-07-14 07:34:26

windowsmysqlcentos

2021-01-08 08:19:36

數據庫TiDB集群

2022-03-14 14:47:21

HarmonyOS操作系統鴻蒙

2019-08-26 09:25:23

RedisJavaLinux

2021-12-10 18:19:55

指標體系設計

2025-04-07 09:40:00

智能體AI代碼

2011-03-25 12:45:49

Oracle SOA

2023-03-14 07:34:47

代碼生成器開發

2025-06-11 01:00:00

2010-07-06 09:43:57

搭建私有云

2010-07-06 09:38:51

搭建私有云

2022-01-04 08:52:14

博客網站Linux 系統開源

2021-07-14 09:00:00

JavaFX開發應用

2011-01-10 14:41:26

2011-05-03 15:59:00

黑盒打印機

2025-05-07 00:31:30

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久一区二区三区电影 | 国产激情91久久精品导航 | 国产美女在线观看 | 午夜免费在线电影 | 久久国产亚洲 | 日本欧美在线观看视频 | 三级在线免费观看 | 国产精品国产精品国产专区不片 | 欧美国产精品一区二区三区 | 久久99精品国产 | 中文一区| 久久久www成人免费精品 | 第四色播日韩第一页 | 国产精品1区2区3区 中文字幕一区二区三区四区 | 亚洲国产成人在线观看 | 二区精品 | 午夜精品一区二区三区在线 | 一区二区三区视频在线免费观看 | 精品国产乱码久久久久久闺蜜 | 国产黄色网址在线观看 | 国产三级一区二区 | 福利国产| 野狼在线社区2017入口 | 欧美情趣视频 | a在线观看 | 日韩免费福利视频 | 一级黄色录像毛片 | 一区二区三区四区国产 | 一区二区在线不卡 | 日韩欧美国产一区二区三区 | 欧美a级成人淫片免费看 | 欧美亚洲国产一区二区三区 | 99re在线视频| 色综合99 | 精品欧美乱码久久久久久 | 一区二区在线不卡 | 91精品久久久久久久久久 | 亚洲精品国产偷自在线观看 | 国产h视频 | aaa精品| 国产免费一区二区三区 |