部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas

這篇文章主要介紹“部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas”,在日常操作中,相信很多人在部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),定海企業(yè)網(wǎng)站建設(shè),定海品牌網(wǎng)站建設(shè),網(wǎng)站定制,定海網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷(xiāo),網(wǎng)絡(luò)優(yōu)化,定海網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

前言

arthas是啥可能大家都知道了,為了湊字?jǐn)?shù),我把官方的介紹再抄一下

Arthas 是Alibaba開(kāi)源的Java診斷工具,深受開(kāi)發(fā)者喜愛(ài)。當(dāng)你遇到以下類似問(wèn)題而束手無(wú)策時(shí),Arthas可以幫助你解決:

  1. 這個(gè)類從哪個(gè) jar 包加載的?為什么會(huì)報(bào)各種類相關(guān)的 Exception?

  2. 我改的代碼為什么沒(méi)有執(zhí)行到?難道是我沒(méi) commit?分支搞錯(cuò)了?

  3. 遇到問(wèn)題無(wú)法在線上 debug,難道只能通過(guò)加日志再重新發(fā)布嗎?

  4. 線上遇到某個(gè)用戶的數(shù)據(jù)處理有問(wèn)題,但線上同樣無(wú)法 debug,線下無(wú)法重現(xiàn)!

  5. 是否有一個(gè)全局視角來(lái)查看系統(tǒng)的運(yùn)行狀況?

  6. 有什么辦法可以監(jiān)控到JVM的實(shí)時(shí)運(yùn)行狀態(tài)?

  7. 怎么快速定位應(yīng)用的熱點(diǎn),生成火焰圖?

今天不詳細(xì)講如何使用arthas,因?yàn)橹坝袑iT(mén)寫(xiě)了一篇博文介紹過(guò),感興趣的朋友可以查看如下鏈接

java應(yīng)用線上診斷神器--Arthas

隨著容器化的火熱,可能有相當(dāng)一部分的項(xiàng)目都是基于docker部署,今天主要就聊下運(yùn)行在docker環(huán)境中的springboot項(xiàng)目,如何啟用arthas

docker環(huán)境中的springboot項(xiàng)目,如何啟用arthas

方案一、進(jìn)入容器內(nèi)部執(zhí)行相應(yīng)命令

 docker exec -it d2ce06ad8855 /bin/bash
 進(jìn)入容器后,再運(yùn)行
 curl -O https://arthas.aliyun.com/arthas-boot.jar
 java -jar arthas-boot.jar

這種方案的弊端在于容器銷(xiāo)毀后,下次運(yùn)行容器后,要再次下載arthas-boot.jar

方案二、把a(bǔ)rthas安裝到基礎(chǔ)鏡像

FROM openjdk:8-jdk-alpine
VOLUME /tmp
#ENV JAVA_OPTS="-Dcom.sun.management.jmxremote.port=39083 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"
ENV JAVA_OPTS=""
COPY localtime /etc/localtime
RUN echo "Asia/Shanghai" > /etc/timezone
ONBUILD COPY app.jar app.jar

ARG ARTHAS_VERSION="3.5.0"
ARG MIRROR=false

ENV MAVEN_HOST=https://repo1.maven.org/maven2 \
    ALPINE_HOST=dl-cdn.alpinelinux.org \
    MIRROR_MAVEN_HOST=https://maven.aliyun.com/repository/public \
    MIRROR_ALPINE_HOST=mirrors.aliyun.com 

# if use mirror change to aliyun mirror site
RUN if $MIRROR; then MAVEN_HOST=${MIRROR_MAVEN_HOST} ;ALPINE_HOST=${MIRROR_ALPINE_HOST} ; sed -i "s/dl-cdn.alpinelinux.org/${ALPINE_HOST}/g" /etc/apk/repositories ; fi && \
    # https://github.com/docker-library/openjdk/issues/76
    apk add --no-cache tini && \ 
    # download & install arthas
    wget -qO /tmp/arthas.zip "${MAVEN_HOST}/com/taobao/arthas/arthas-packaging/${ARTHAS_VERSION}/arthas-packaging-${ARTHAS_VERSION}-bin.zip" && \
    mkdir -p /opt/arthas && \
    unzip /tmp/arthas.zip -d /opt/arthas && \
    rm /tmp/arthas.zip

ENTRYPOINT ["/sbin/tini", "--", "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]

方案三、使用arthas-spring-boot-starter

1、在項(xiàng)目的pom.xml引入

 <dependency>
            <groupId>com.taobao.arthas</groupId>
            <artifactId>arthas-spring-boot-starter</artifactId>
            <version>${arthas.version}</version>
        </dependency>

2、在yml進(jìn)行配置

這邊配置又有兩種方式

  • 2.1、配置arthas tunnel server實(shí)現(xiàn)遠(yuǎn)程管理

注:通過(guò)Arthas Tunnel Server/Client 來(lái)遠(yuǎn)程管理/連接多個(gè)Agent

因此我們首先要先安裝Arthas Tunnel Server/Client

a、下載部署arthas tunnel server

https://github.com/alibaba/arthas/releases

b、啟動(dòng)arthas-tunnel-server

示例

java -jar  arthas-tunnel-server-3.5.0-fatjar.jar

注:默認(rèn)情況下,arthas tunnel server的web端口是8080,arthas agent連接的端口是7777

c、在項(xiàng)目的yml做如下配置

arthas:
  agent-id: ${ARTHAS_AGENT_ID:hsehdfsfghhwertyfad}
  app-name: ${spring.application.name}
  tunnel-server: ${ARTHAS_TUNNEL_SERVER:ws://localhost:7777/ws}

注:agentId要保持唯一,否則會(huì)在tunnel server上沖突,不能正常工作

d、效果演示

部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas

  • 2.2、直接在項(xiàng)目的yml做如下配置

arthas:
 # 通過(guò)http訪問(wèn)的端口
  http-port: 8563
  # 通過(guò)telnet訪問(wèn)的端口
  telnet-port: 3658
  session-timeout: 1800
  # 綁定的ip
  ip: 0.0.0.0

注:如果配置 arthas.telnetPort為 -1 ,則不監(jiān)聽(tīng) telnet端口。如果配置 arthas.telnetPort為 0 ,則隨機(jī)telnet端口。arthas.httpPort類似

效果演示

  • a、通過(guò)http訪問(wèn)

部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas

  • b、通過(guò)telnet訪問(wèn)

部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas

arthas入門(mén)使用

核心思想通過(guò)help命令,先通過(guò)help了解一下arthas有啥命令

部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas 然后過(guò)help 你感興趣的命令,比如你對(duì)thread這個(gè)命令很感興趣,則在命令行輸入

help thread

部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas 示例演示,比如排查項(xiàng)目中是否存在死鎖

thread -b

部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas 我們也比較常用dashboard命令來(lái)查看cpu、gc等信息

dashboard

部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas

總結(jié)

arthas確實(shí)降低我們排查java問(wèn)題的難度,但arthas的命令那么多,很多時(shí)候我們都記不住,就算能記,我也不會(huì)去記,我正常使用的套路是先help 命令,然后找到相應(yīng)的示例,最后照貓畫(huà)虎。

如果使用http或者telnet的話,基于安全考量,那個(gè)ip最好是使用內(nèi)網(wǎng)ip,不要像我示例直接0.0.0.0,我是為了演示方便。

demo鏈接

https://github.com/lyb-geek/springboot-learning/tree/master/springboot-arthas

到此,關(guān)于“部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

分享題目:部署在docker容器里面的springboot項(xiàng)目怎么啟用arthas
轉(zhuǎn)載來(lái)于:http://muchs.cn/article46/pdgjhg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)、移動(dòng)網(wǎng)站建設(shè)網(wǎng)站改版、品牌網(wǎng)站建設(shè)搜索引擎優(yōu)化、網(wǎng)站營(yíng)銷(xiāo)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

小程序開(kāi)發(fā)