Java遠(yuǎn)程調(diào)試保姆級(jí)教程(附詳細(xì)圖文)
背景
測(cè)試環(huán)境報(bào)錯(cuò),但很難排查到問(wèn)題,可以像本地debug的方式來(lái)調(diào)試遠(yuǎn)程代碼
準(zhǔn)備
1. xshell + 遠(yuǎn)程服務(wù)
2. idea + 本地代碼
一、新增遠(yuǎn)程調(diào)試配置
1. idea -> run -> edit configration
2.確定一個(gè)未被占用遠(yuǎn)程和本地占用的端口,開(kāi)始編輯配置, 我這邊用的jdk8
復(fù)制出來(lái)的參數(shù):
-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8205
二、服務(wù)添加遠(yuǎn)程調(diào)試參數(shù)
登錄服務(wù)器模塊,添加在第二步驟中復(fù)制的監(jiān)聽(tīng)參數(shù),然后重啟服務(wù), 手動(dòng)啟動(dòng)jar, 或者編輯啟動(dòng)腳本,
手動(dòng)啟動(dòng)參數(shù)如下:
java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8205 -jar -Xmx512m -Xms512m web-4.2.jar
手動(dòng)啟動(dòng)結(jié)果如下:
調(diào)整啟動(dòng)腳本示例如下:
手動(dòng)啟動(dòng)會(huì)提示:Listening for transport dt_socket at address: 8205
三、通過(guò)xshell將轉(zhuǎn)發(fā)端口8205透?jìng)鞯奖镜?/h2>
遠(yuǎn)程監(jiān)聽(tīng)轉(zhuǎn)發(fā)接口為8205,本地監(jiān)聽(tīng)配置端口為8205,所以透?jìng)骶褪沁h(yuǎn)程:8205 -> localhost:8205
四、開(kāi)始遠(yuǎn)程調(diào)試
1.點(diǎn)擊idea 的遠(yuǎn)程配置Debug 按鈕,啟動(dòng)遠(yuǎn)程調(diào)試web服務(wù),成功啟動(dòng)頁(yè)面如下:
2.對(duì)指定接口打上斷點(diǎn), 點(diǎn)擊頁(yè)面,觸發(fā)接口,就會(huì)自動(dòng)進(jìn)入idea中斷點(diǎn)位置
TIPS:
問(wèn)題1:idea添加配置后啟動(dòng)debug按鈕無(wú)法點(diǎn)擊
排查遠(yuǎn)程服務(wù)是否啟動(dòng)失敗, 排查監(jiān)聽(tīng)端口是否透?jìng)鞒晒?/p>
問(wèn)題2:?jiǎn)?dòng)debug后等待一段時(shí)間彈出握手失敗報(bào)錯(cuò),然后停止監(jiān)聽(tīng)
Error running '82-12001' Unable to open debugger port (localhost:8205): java.io.IOException "handshake failed - connection prematurally closed"
去排查xshell透出的端口,是否跟遠(yuǎn)程轉(zhuǎn)發(fā)端口一致。如上述步驟中所示:
web遠(yuǎn)程啟動(dòng)端口為12001,轉(zhuǎn)發(fā)到8205端口, 此時(shí)我們需要將監(jiān)聽(tīng)的8205端口傳到本地localhost, 這樣idea配置才能正常握手8025
問(wèn)題3:調(diào)試斷點(diǎn)無(wú)法進(jìn)入
遠(yuǎn)程代碼最好跟本地一致,以防出現(xiàn)斷點(diǎn)無(wú)法進(jìn)入情況
知識(shí)點(diǎn):
idea添加遠(yuǎn)程配置時(shí)生成的JVM參數(shù)是用于配置Java遠(yuǎn)程調(diào)試的核心參數(shù),下面我詳細(xì)解釋每個(gè)部分的含義:
完整參數(shù):
-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8205
分解解釋:
-agentlib:jdwp
表示加載JDWP(Java Debug Wire Protocol)代理庫(kù)
這是Java調(diào)試的標(biāo)準(zhǔn)協(xié)議實(shí)現(xiàn)
transport=dt_socket
指定調(diào)試器與被調(diào)試JVM之間的通信傳輸方式
dt_socket表示使用socket網(wǎng)絡(luò)通信(最常用)
替代選項(xiàng):dt_shmem(共享內(nèi)存,僅限本地調(diào)試)
server=y
定義JVM作為調(diào)試服務(wù)端(等待調(diào)試器連接)
如果設(shè)為n,則JVM會(huì)主動(dòng)連接調(diào)試器(較少使用)
suspend=n
控制JVM啟動(dòng)時(shí)是否暫停等待調(diào)試器連接
y:暫停,直到調(diào)試器連接(適合調(diào)試啟動(dòng)過(guò)程)
n:立即啟動(dòng),調(diào)試器可以隨時(shí)連接(生產(chǎn)環(huán)境推薦)
address=8205
指定調(diào)試端口號(hào)(這里是8205)
JDK 9+需要格式:address=*:8205(允許任意IP連接)
默認(rèn)只接受本地連接,如需遠(yuǎn)程需明確指定IP
總結(jié)
到此這篇關(guān)于Java遠(yuǎn)程調(diào)試保姆級(jí)教程的文章就介紹到這了,更多相關(guān)Java遠(yuǎn)程調(diào)試內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java關(guān)鍵字instanceof用法及實(shí)現(xiàn)策略
instanceof 運(yùn)算符是用來(lái)在運(yùn)行時(shí)判斷對(duì)象是否是指定類及其父類的一個(gè)實(shí)例。這篇文章主要介紹了Java關(guān)鍵字instanceof用法解析,需要的朋友可以參考下2020-08-08Java Lock接口實(shí)現(xiàn)原理及實(shí)例解析
這篇文章主要介紹了Java Lock接口實(shí)現(xiàn)原理及實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04實(shí)例講解Java編程中數(shù)組反射的使用方法
這篇文章主要介紹了Java編程中數(shù)組反射的使用方法,通過(guò)編寫(xiě)數(shù)組反射工具類可以重用許多基礎(chǔ)代碼,減少對(duì)類型的判斷過(guò)程,需要的朋友可以參考下2016-04-04java調(diào)用Oracle存儲(chǔ)過(guò)程的方法實(shí)例
這篇文章介紹了java調(diào)用Oracle存儲(chǔ)過(guò)程的方法實(shí)例,有需要的朋友可以參考一下2013-09-09Shiro實(shí)現(xiàn)session限制登錄數(shù)量踢人下線功能
這篇文章主要介紹了Shiro實(shí)現(xiàn)session限制登錄數(shù)量踢人下線,本文記錄的是shiro采用session作為登錄方案時(shí),對(duì)用戶進(jìn)行限制數(shù)量登錄,以及剔除下線,需要的朋友可以參考下2023-11-11java web項(xiàng)目里ehcache.xml介紹
java web項(xiàng)目里ehcache.xml介紹,需要的朋友可以參考一下2013-03-03SpringBoot中如何使用Assert進(jìn)行斷言校驗(yàn)
Java?提供了內(nèi)置的?assert?機(jī)制,而?Spring?框架也提供了更強(qiáng)大的?Assert?工具類來(lái)幫助開(kāi)發(fā)者進(jìn)行參數(shù)校驗(yàn)和狀態(tài)檢查,下面我們就來(lái)看看SpringBoot中如何使用Assert進(jìn)行斷言校驗(yàn)吧2025-07-07