在Docker容器中使用Arthas的詳細步驟
Arthas(阿爾薩斯) 能為你做什么?
Arthas是Alibaba開源的Java診斷工具,深受開發(fā)者喜愛。當你遇到以下類似問題而束手無策時,
Arthas可以幫助你解決:這個類從哪個 jar 包加載的?為什么會報各種類相關(guān)的 Exception?我改的代碼為什么沒有執(zhí)行到?難道是我沒 commit?分支搞錯了?遇到問題無法在線上 debug,難道只能通過加日志再重新發(fā)布嗎?線上遇到某個用戶的數(shù)據(jù)處理有問題,但線上同樣無法 debug,線下無法重現(xiàn)!是否有一個全局視角來查看系統(tǒng)的運行狀況?有什么辦法可以監(jiān)控到JVM的實時運行狀態(tài)?怎么快速定位應(yīng)用的熱點,生成火焰圖?怎樣直接從JVM內(nèi)查找某個類的實例?
Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同時提供豐富的Tab自動補全功能,進一步方便進行問題的定位和診斷。
具體內(nèi)容請查看官方文檔,各個命令有詳細的說明: https://arthas.aliyun.com/doc/
本文不是介紹arthas怎么用的。這里要說的是,如何在我們的docker容器中,使用arthas。
鑒于我們在docker容器中使用arthas比較繁瑣,需要找到容器id,需要復(fù)制整個arthas目錄到容器中,需要進入容器,需要切換到目標服務(wù)的用戶,需要啟動arthas,這些步驟對于很多對linux命令和docker命令不熟悉的同學(xué)并不友好。
因此我寫了個腳本,可以直接替代以上步驟,使用效果如下圖所示:

直接在腳本后,輸入完整的服務(wù)名(這里取的是容器的IMAGE名稱),即可使用,簡單便捷。
使用方法:首先需要在linux服務(wù)器上解壓arhas-bin.zip,解壓出來即是arthas軟件。確保本機已安裝docker
arhas-bin.zip下載目錄:https://github.com/alibaba/arthas/releases



將arthasDocker.sh腳本,放到剛才解壓的arthas目錄中,打開腳本,編輯ARTHAS_PATH變量,改為你arthas放置的目錄。
arthasDocker.sh腳本內(nèi)容:
#!/bin/bash
#
# author: dijia478
# date: 2020-8-20 18:14:38
# desc: 本腳本需要放到arthas的目錄中,連同整個目錄一起復(fù)制到docker容器中去。主要用途為在容器中切換目標服務(wù)的用戶,并啟動arthas
echo "開始查詢目標服務(wù)的進程id和用戶..."
PID=`ps -eo pid,user=aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa -o args | grep java | grep -v grep | awk '{print $1}'`
echo "目標服務(wù)的進程id為${PID}"
USER=`ps -eo pid,user=aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa -o args | grep java | grep -v grep | awk '{print $2}'`
echo "目標服務(wù)的用戶為${USER}"
if [[ ! -d "/home/${USER}" ]]
then
mkdir -p /home/${USER}
echo "創(chuàng)建目錄/home/${USER}"
fi
chmod 777 /home/${USER}
echo "開始切換用戶并啟動arthas..."
# 下面的arthas路徑需要修改,并且要和startArthas.sh腳本中保持一致
ARTHAS_PATH="/opt/arthas"
su ${USER} -c "java -jar ${ARTHAS_PATH}/arthas-client.jar 127.0.0.1 3658 -c 'stop'"
su ${USER} -c "java -jar ${ARTHAS_PATH}/arthas-boot.jar ${PID}"
將startArthas.sh腳本,放到linux服務(wù)器上,建議放到~目錄下,打開腳本,編輯ARTHAS_PATH變量,改為你arthas放置的目錄。然后賦予腳本執(zhí)行權(quán)限
startArthas.sh腳本內(nèi)容:
#! /bin/bash
#
# author: dijia478
# date: 2020-9-18 10:36:27
# desc: 本腳本主要用途為啟動arthas診斷工具來診斷某個docker中java服務(wù)
if [[ ${1} == '' ]]
then
echo "請選擇一個服務(wù):"
sudo docker ps | awk 'NR>1 {print $2}'
exit 0
fi
echo "開始尋找服務(wù)${1}的容器..."
DOCKER_LIST=`sudo docker ps | awk 'NR>1 {print $2}'`
FLAG=0
for i in ${DOCKER_LIST[@]}
do
if [[ ${i} == ${1} ]]
then
FLAG=1
break
fi
done
if [[ ${FLAG} == 0 ]]
then
DOCKER_NAME=`sudo docker ps | awk 'NR>1 {print $2}' | grep ${1}`
if [[ ${DOCKER_NAME} == '' ]]
then
echo "未找到該服務(wù)的容器,請重新選擇服務(wù):"
sudo docker ps | awk 'NR>1 {print $2}'
else
echo "請輸入服務(wù)的完整名稱:"
sudo docker ps | awk 'NR>1 {print $2}' | grep ${1}
fi
else
ID=`sudo docker ps --filter ancestor=${1} | awk '{print $1}' | sed -n '2p'`
echo "找到容器${ID}"
echo "開始復(fù)制arthas到容器中..."
# 下面的arthas路徑需要修改,并且要和arthasDocker.sh腳本中保持一致
ARTHAS_PATH="/opt/arthas"
sudo docker exec -it ${ID} /bin/bash -c "rm -rf ${ARTHAS_PATH}"
sudo docker cp ${ARTHAS_PATH} ${ID}:${ARTHAS_PATH}
echo "復(fù)制完成"
echo "即將進入容器中..."
sudo docker exec -it ${ID} /bin/bash -c "bash ${ARTHAS_PATH}/arthasDocker.sh"
fi
最后直接運行 startArthas.sh 腳本就可以了
? 版權(quán)聲明文章版權(quán)歸作者所有,歡迎轉(zhuǎn)載,但必須給出原文鏈接,否則保留追究法律責(zé)任的權(quán)利THE END
到此這篇關(guān)于如何在Docker容器中使用Arthas的文章就介紹到這了,更多相關(guān)Docker使用Arthas內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker利用DockerFile創(chuàng)建部署NVIDIA+PyTorch容器的詳細過程
這篇文章主要介紹了Docker利用DockerFile創(chuàng)建部署NVIDIA+PyTorch容器的詳細過程,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06
kali安裝docker及搭建漏洞環(huán)境的詳細教程
Docker?是一個開源的應(yīng)用容器引擎,讓開發(fā)者可以打包他們的應(yīng)用以及依賴包到一個可移植的容器中,然后發(fā)布到任何流行的Linux機器上,也可以實現(xiàn)虛擬化,本文重點給大家介紹kali安裝docker及搭建漏洞環(huán)境的過程,感興趣的朋友一起看看吧2022-05-05

