CentOS7.4上搭建rocketMQ集群

来源:https://www.cnblogs.com/lnsis/archive/2018/12/21/10153896.html
-Advertisement-
Play Games

一、rocketMQ集群部署方案優缺點對比:多Master模式(2m-noslave) :一個集群無Slave,全是Master,例如2個Master或者3個Master優點:配置簡單,單個Master宕機或重啟維護對應用無影響,在磁碟配置為RAID10時,即使機器宕機不可恢復情況下,由於RAID1 ...


一、rocketMQ集群部署方案優缺點對比: 多Master模式(2m-noslave) : 一個集群無Slave,全是Master,例如2個Master或者3個Master 優點:配置簡單,單個Master宕機或重啟維護對應用無影響,在磁碟配置為RAID10時,即使機器宕機不可恢復情況下,由於RAID10磁碟非常可靠,消息也不會丟(非同步刷盤丟失少量消息,同步刷盤一條不丟)。性能最高。 缺點:單台機器宕機期間,這台機器上未被消費的消息在機器恢復之前不可訂閱,消息實時性會受到受到影響。 多Master多Slave模式,非同步複製(2m-2s-async) : 每個Master配置一個Slave,有多對Master-Slave,HA採用非同步複製方式,主備有短暫消息延遲,毫秒級。 優點:即使磁碟損壞,消息丟失的非常少,且消息實時性不會受影響,因為Master宕機後,消費者仍然可以從Slave消費,此過程對應用透明。不需要人工干預。性能同多Master模式幾乎一樣。 缺點:Master宕機,磁碟損壞情況,會丟失少量消息。 多Master多Slave模式,同步雙寫(2m-2s-sync) 每個Master配置一個Slave,有多對Master-Slave,HA採用同步雙寫方式,主備都寫成功,嚮應用返回成功。 優點:數據與服務都無單點,Master宕機情況下,消息無延遲,服務可用性與數據可用性都非常高 缺點:性能比非同步複製模式略低,大約低10%左右,發送單個消息的RT會略高。目前主宕機後,備機不能自動切換為主機,後續會支持自動切換功能。  二、環境 1、版本 JDK:jdk1.8 rocketMQ:4.3.2,rocketMQ下載地址:wget http://mirrors.hust.edu.cn/apache/rocketmq/4.3.2/rocketmq-all-4.3.2-bin-release.zip rocketmq-console-ng版本:1.0.0 2、角色 rocketmq-console-ng(監控管理): 188.188.10.60:8080 NameServer節點: 188.188.10.60:9876 188.188.10.23:9876 broker: 188.188.10.60:10911 master broker-a 188.188.10.23:10911 slave broker-a 188.188.10.125:10911 master broker-b 188.188.10.209:10911 slave broker-b 3、host解析 vim /etc/hosts 188.188.10.60 broker-a 188.188.10.23 broker-b

 

三、部署 1、上傳rocketMQ包,並解壓到/usr/local/rocketMQ 2、編輯配置文件,預設的配置不能滿足我們的需求,需要我們自己添加定製相關的參數,由於我們要部署的是多master多slave的非同步方案,所以我們修改或者添加/chj/app/rocketmq/conf/2m-2s-async目錄下的配置文件即可(建議在broker的一臺節點上把所有的配置文件都撰寫好,統一分發到所有節點,保持所有節點的配置文件一致,起服務的時候不同的節點使用不同的配置文件即可,方便後期維護) A、4個文件的差異配置vim broker-a.properties brokerName=broker-a brokerId=0 brokerRole=ASYNC_MASTER vim broker-a-s.properties brokerName=broker-a brokerId=1 brokerRole=SLAVE vim broker-b.properties brokerName=broker-b brokerId=0 brokerRole=ASYNC_MASTER vim broker-b-s.properties brokerName=broker-b brokerId=1 brokerRole=SLAVE



B、除了上面的配置每個配置文件不一樣,下麵的配置都一樣

 

#所屬集群名字 brokerClusterName=rocketmq-cluster #broker名字,註意此處不同的配置文件填寫的不一樣, #brokerName=broker-a #0 表示 Master,>0 表示 Slave #brokerId=0 #nameServer地址,分號分割 namesrvAddr=188.188.10.60:9876;188.188.10.23:9876 #在發送消息時,自動創建伺服器不存在的topic,預設創建的隊列數 defaultTopicQueueNums=4 #是否允許 Broker 自動創建Topic,建議線下開啟,線上關閉 autoCreateTopicEnable=true #是否允許 Broker 自動創建訂閱組,建議線下開啟,線上關閉 autoCreateSubscriptionGroup=true #Broker 對外服務的監聽埠 listenPort=10911 #刪除文件時間點,預設凌晨 4點 deleteWhen=04 #文件保留時間,預設 48 小時 fileReservedTime=120 #commitLog每個文件的大小預設1G mapedFileSizeCommitLog=1073741824 #ConsumeQueue每個文件預設存30W條,根據業務情況調整 mapedFileSizeConsumeQueue=300000 #destroyMapedFileIntervalForcibly=120000 #redeleteHangedFileInterval=120000 #檢測物理文件磁碟空間 diskMaxUsedSpaceRatio=88 #存儲路徑 storePathRootDir=/usr/local/rocketMQ/store #commitLog 存儲路徑 storePathCommitLog=/usr/local/rocketMQ/store/commitlog #消費隊列存儲路徑存儲路徑 storePathConsumeQueue=/usr/local/rocketMQ/store/consumequeue #消息索引存儲路徑 storePathIndex=/usr/local/rocketMQ/store/index #checkpoint 文件存儲路徑 storeCheckpoint=/usr/local/rocketMQ/store/checkpoint #abort 文件存儲路徑 abortFile=/usr/local/rocketMQ/store/abort #限制的消息大小 maxMessageSize=65536 #flushCommitLogLeastPages=4 #flushConsumeQueueLeastPages=2 #flushCommitLogThoroughInterval=10000 #flushConsumeQueueThoroughInterval=60000 #Broker 的角色 #- ASYNC_MASTER 非同步複製Master #- SYNC_MASTER 同步雙寫Master #- SLAVE #brokerRole=ASYNC_MASTER #刷盤方式 #- ASYNC_FLUSH 非同步刷盤 #- SYNC_FLUSH 同步刷盤 flushDiskType=ASYNC_FLUSH #checkTransactionMessageEnable=false #發消息線程池數量 #sendMessageThreadPoolNums=128 #拉消息線程池數量 #pullMessageThreadPoolNums=128 3、修改日誌文件路徑 cd /usr/local/rocketMQ/conf sed 's#${user.home}#/usr/local/rocketMQ#g' *.xml -i 4、啟動 nameserver啟動:(兩個節點啟動方式一樣) nohup sh /usr/local/rocketMQ/bin/mqnamesrv >/dev/null 2>&1 & broker啟動: Master-a: nohup sh /usr/local/rocketMQ/bin/mqbroker -c /usr/local/rocketMQ/conf/2m-2s-async/broker-a.properties >/dev/null 2>&1 & Slave-a: nohup sh /usr/local/rocketMQ/bin/mqbroker -c /usr/local/rocketMQ/conf/2m-2s-async/broker-a-s.properties >/dev/null 2>&1 & Master-b: nohup sh /usr/local/rocketMQ/bin/mqbroker -c /usr/local/rocketMQ/conf/2m-2s-async/broker-b.properties >/dev/null 2>&1 & Slave-b: nohup sh /usr/local/rocketMQ/bin/mqbroker -c /usr/local/rocketMQ/conf/2m-2s-async/broker-b-s.properties >/dev/null 2>&1 &5、rocket-console-ng服務: nohup java -jar rocketmq-console-ng-1.0.0.jar --server.port=8889 --rocketmq.config.namesrvAddr=188.188.10.60:9876;188.188.10.23:9876 & http://188.188.10.60:8889/#/

 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本篇我將帶著大家一起來對Dapper進行下封裝並實現基本的增刪改查、分頁操作的同步非同步方法的實現(已實現MSSQL,MySql,PgSQL)。同時我們再實現一下倉儲層的代碼生成器,這樣的話,我們只需要結合業務來實現具體的業務部分的代碼就可以了,可以大大減少我們重覆而又繁瑣的增刪改查操作,多留點時間給 ...
  • Windows -- cmd命令: ipconfig 和 nbtstat ...
  • 本章學習內容: 1.常見符號 2.命令分隔符-分號";" 3.雙分號 ";;" 4. '單引號和"雙引號 5.`反引號和$() 6.${}和$ 7.冒號: 8.()小括弧 9.(())雙括弧 10.{}大括弧 11.[]和[[]]之間的條件測試區別 12.~波浪號 13.延時 14.變數賦值的註意 ...
  • 有的時候我們需要批量創建文件做測試,為了做區分,一般只要稍稍動動文件名即可,MV命令既可以移動文件,也是可以修改文件名的,但批量修改文件名MV做不到,此時,我們可以用rename命令批量修改是蠻不錯的方法,當然也有其他方法的,具體如下: 語法: rename [ -v ] [ -n ] [ -f ] ...
  • 在客戶端向服務端發送http請求時,若返回狀態碼為304 Not Modified 則表明此次請求為條件請求。在請求頭中有兩個請求參數:If-Modified-Since 和 If-None-Match。 當客戶端緩存了目標資源但不確定該緩存資源是否是最新版本的時候, 就會發送一個條件請求。在進行條 ...
  • 最近剛入門SDK編程,在 我終於知道為什麼windowsApi學的人這麼少了 這篇文章中,確實發現了這樣的問題,我的教程使用VS2013->Windows桌面->win32,就誕生了能使用WinMain()的介面的Windows程式。而換成VS2017來編譯,卻發現問題不止這裡 首先,參考某些資料得 ...
  • iostat命令用途:主要用於監控系統設備的IO負載情況,iostat首次運行時顯示自系統啟動開始的各項統計信息,之後運行iostat將顯示自上次運行該命令以後的統計信息。用戶可以通過指定統計的次數和時間來獲得所需的統計信息。iostat有一個弱點,就是它不能對某個進程進行深入分析,僅對系統的整體情 ...
  • 一、SUID、SGID、SBIT簡介 SUID:對一個可執行文件,不是以發起者身份來獲取資源,而是以可執行文件的屬主身份來執行。SGID:對一個可執行文件,不是以發起者身份來獲取資源,而是以可執行文件的屬組身份來執行。SBIT:粘滯位,通常對目錄而言。通常對於全局可寫目錄(other也可寫)來說,讓 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...