在linux環境安裝單機RocketMQ
我們準備安裝的Apache-RocketMQ需要通過Maven去編譯後才能啟動,所以首先要保證linux伺服器中有安裝java環境以及Maven。
1.下載maven並解壓
maven下載地址 ofollow,noindex">maven.apache.org/download.cg… 找到合適的maven版本
wget http://mirrors.shu.edu.cn/apache/maven/maven-3/3.6.0/source/apache-maven-3.6.0-src.tar.gz 複製程式碼
通過上面的命令,下載maven壓縮包到你想要安裝的目錄下。 解壓安裝包
tar -zxvfapache-maven-3.6.0-src.tar.gz 複製程式碼
解壓後可以建立一個軟連線,方便配置環境變數
ln -s apache-maven-3.6.0-src.tar.gz maven 複製程式碼
2.配置環境變數
開啟配置檔案
vim /etc/profile 複製程式碼
在檔案末尾追加環境變數
MAVEN_HOME=/usr/local/maven export MAVEN_HOME export PATH=${PATH}:${MAVEN_HOME}/bin 複製程式碼
/usr/local就是你存放maven的目錄
讓配置檔案立刻生效
source /etc/profile 複製程式碼
3.安裝成功
控制檯輸入mvn -v 出現版本號說明maven安裝成功

二、下載安裝RocketMQ
1.下載解壓Apache-RocketMQ
github.com/apache/rock… 這個網址可以看到多個版本的RocketMQ
wget https://github.com/apache/rocketmq/archive/rocketmq-all-4.3.0.tar.gz 複製程式碼
在/user/local/下新建rocketmq資料夾,將壓縮包下載到這個資料夾,然後解壓
tar -zxvf rocketmq-all-4.3.0.tar.gz 複製程式碼
解壓後文件夾如下

2.編譯
要使用用maven編譯專案,
mvn -Prelease-all -DskipTests clean install -U 複製程式碼
開始編譯

最後出現BUILD SUCCESS就說明已經編譯成功

3.配置環境變數
cd distribution/target/apache-rocketmq/ pwd 複製程式碼
記錄這個路徑,需要配置到環境變數 開啟配置檔案
vim /etc/profile 複製程式碼
在最後追加兩行,wq儲存退出
export rocketmq=/usr/local/rockemq-source/rocketmq/distribution/target/apache-rocketmq export PATH=$PATH:$rocketmq/bin 複製程式碼

讓配置檔案立馬生效
source /etc/profile 複製程式碼
新建日誌資料夾
mkdir /usr/local/log/rocketmqlogs 複製程式碼
4.啟動RocketMQ
啟動:
nohup mqnamesrv >/usr/local/log/rocketmqlogs/namesrv.log 2>&1 & 複製程式碼
檢視日誌:
tail -f /user/local/log/rocketmqlogs/namesrv.log 複製程式碼
正常啟動的話,會出現

啟動broker服務:
nohup mqbroker -n localhost:9876 >/usr/local/log/rocketmqlogs/broker.log 2>&1 & 複製程式碼
檢視日誌:
tail -f /user/local/log/rocketmqlogs/broker.log 複製程式碼
正常啟動的話,會出現

但是由於RocketMQ預設的java記憶體配置有點大,伺服器記憶體沒那麼大就會報錯
Java HotSpot(TM) 64-Bit Server VM warning: Using the DefNew young collector with the CMS collector is deprecated and will likely be removed in a future release Java HotSpot(TM) 64-Bit Server VM warning: UseCMSCompactAtFullCollection is deprecated and will likely be removed in a future release. Java HotSpot(TM) 64-Bit Server VM warning: MaxNewSize (131072k) is equal to or greater than the entire heap (131072k).A new max generation size of 131008k will be used. 複製程式碼
只要修改一下bin目錄下的runserver.sh和runbroker.sh檔案的配置就好了

按照伺服器情況修改就好了
JAVA_OPT="${JAVA_OPT} -server -Xms128m -Xmx256m -Xmn128m" 複製程式碼
修改後重新啟動就應該可以了 執行下面命令,檢視RocketMQ程序
ps -ef|grep rocketmq 複製程式碼

5.關閉
mqshutdown namesrv mqshutdown broker 複製程式碼
三、搭建視覺化管理控制檯RocketMQ Console
1.下載
RocketMQ安裝成功後,想要比較簡單的訪問一下,就可以使用RocketMQ Console RocketMQ有一個對其擴充套件的開源專案 rocketmq-externals ,裡面有個專案就是 RocketMQ Console 整個專案下載下來有點慢,所以就只下Console那個分支專案就好了

2.配置啟動
將專案匯入,然後配置配置檔案

將伺服器地址配置好

啟動專案
如果出現下面的連結失敗問題,可能是你的伺服器埠沒有開放,把安全組規則配置一下就好了,最好把9876,10909,10911都開放了
java.lang.RuntimeException: org.apache.rocketmq.remoting.exception.RemotingConnectException: connect to <x.x.x.x:9876> failed 複製程式碼
如果埠開放了,但是還是報connect to x.x.x.x:10911 failed,那就需要配置一下brokerIP1,broker啟動時,預設ip是本地ip,但是這個ip可能遠端無法訪問。
在RocketMQ目錄新建properties
echo "brokerIP1=外網IP" > broker.properties 複製程式碼
關閉然後重啟broker
mqshutdown broker nohup mqbroker -n localhost:9876 -c 配置檔案路徑/broker.properties >/usr/local/log/rocketmqlog/broker.log 2>&1 & 複製程式碼
重啟console專案,瀏覽器訪問

