遠(yuǎn)程debug調(diào)試入門
1.遠(yuǎn)程DEBUG的必要性
由于部署環(huán)境的差異性,相信很多朋友都碰到過開發(fā)環(huán)境正常測試過的功能在測試環(huán)境甚至生產(chǎn)環(huán)境下出現(xiàn)bug的情況。一般情況下,生產(chǎn)環(huán)境可以采取的手段比較單一,即通過日志的方式獲取運行中的環(huán)境上下文,分析日志文件并嘗試重現(xiàn)bug。這會帶來的問題還是不少的,首先,日志的分析是一項比較耗時的工作;其次,現(xiàn)有的日志記錄不一定能反映出問題,你可能需要多次重復(fù)這個過程(分析日志->猜測問題->加日志->部署->獲取日志)來慢慢逼近問題。倘若是測試環(huán)境,我們還多了一項可供選擇的手段——遠(yuǎn)程調(diào)試——將程序在測試環(huán)境中以debug模式啟動,在本機使用IDEA在工程中設(shè)置斷點進行調(diào)試。
2,IDEA構(gòu)建SpringBoot測試Demo
新建SpringBoot測試項目remote-debug
,只需要web依賴支持即可;版本選用2.2.6.RELEASE(注意,別用2.5.1版本,有坑,親測)
pom.xml:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.2.6.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.java1234</groupId> <artifactId>remote-debug</artifactId> <version>v1.0</version> <name>remote-debug</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
application.yml:
server: port: 80 servlet: context-path: / tomcat: uri-encoding: utf-8
簡單搞個TestController,提供一個Rest接口
package com.java1234.controller; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; /** * @author java1234_小鋒 * @site www.java1234.com * @company Java知識分享網(wǎng) * @create 2021-06-12 15:37 */ @RestController public class TestController { @PostMapping("/test") public String test(Integer id,String name){ System.out.println("id="+id); System.out.println("name="+name); if(id>0){ return "success "+name; }else{ return "fail"; } } }
我們啟動項目,用postman測試下:
測試接口:http://localhost/test 加入Body form-data 參數(shù) id=1,name=marry,Send 測試,返回 success marry,測試OK;
3,測試Demo項目配置支持遠(yuǎn)程調(diào)試
pom.xml里配置jvmArguments
參數(shù) -Xdebug -Xrunjdwp:transport=dt_socket,address=5005,server=y,suspend=n:
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <jvmArguments>-Xdebug -Xrunjdwp:transport=dt_socket,address=5005,server=y,suspend=n</jvmArguments> </configuration> </plugin> </plugins> </build>
加了此配置后,打包后的項目發(fā)布服務(wù)器,可支持遠(yuǎn)程DEBUG;
具體參數(shù)詳解:
-Xdebug 通知JVM工作在DEBUG模式下;
-Xrunjdwp 通知JVM使用(Java debug wire protocol)運行調(diào)試環(huán)境。該參數(shù)同時包含了一系列的調(diào)試選項;
**transport **指定了調(diào)試數(shù)據(jù)的傳送方式,dt_socket是指用SOCKET模式,另有dt_shmem指用共享內(nèi)存方式,其中,dt_shmem只適用于Windows平臺;
address 調(diào)試服務(wù)器的端口號,客戶端用來連接服務(wù)器的端口號;
server=y/n VM 是否需要作為調(diào)試服務(wù)器執(zhí)行;
suspend=y/n 是否在調(diào)試客戶端建立連接之后啟動 VM;
4,IDEA打包jar
我們打包jar包;
右側(cè)Maven工具,雙擊 package打包工具;
一般打包跳過test,可以點擊箭頭所指閃電圖標(biāo),這樣打包速度會快很多;
打包后,在target目錄下,會生成一個jar包;我們把它復(fù)制出來即可;
5,啟動jar并且?guī)訁?shù)支持遠(yuǎn)程調(diào)試
我們把remote-debug-v1.0.jar
放D盤根目錄;
我們啟動jar,并且支持遠(yuǎn)程DEBUG;
java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -jar remote-debug-v1.0.jar
啟動OK,監(jiān)聽socket 5005端口
6,IDEA遠(yuǎn)程DEBUG配置
IDEA要進行遠(yuǎn)程DEBUG,需要進行配置;
1,啟動項下拉,選擇 Edit Configurations...
編輯配置
2,點擊+
,選擇Remote
,添加遠(yuǎn)程DEBUG配置
3,添加遠(yuǎn)程DEBUG配置項,Host和Port,配置后,點擊Apply
和OK
按鈕
7,IDEA遠(yuǎn)程DEBUG測試
1,打測試斷點
我們直接在TestController
類里的test方法上打點斷;
2,選擇遠(yuǎn)程debug啟動項,然后點擊測試調(diào)試按鈕啟動;
3,postman測試
4,成功進入斷點
我們走完斷點;
5,啟動的jar包打印信息,測試OK
8,eclipse遠(yuǎn)程DEBUG實現(xiàn)
1,右擊項目 -> Debug As -> Debug Configurations…
2,找到 Remote Java Application
然后右擊 New
3,配置Host
和Port
,點擊Debug
按鈕,即可實現(xiàn)遠(yuǎn)程DEBUG
9,打war包方式配置遠(yuǎn)程DEBUG
如果打的是war包,需要兩個步驟:
1.將 web 應(yīng)用部署到 Tomcat 的 webapp 目錄下
2.修改 Tomcat/bin/startup.bat 文件,在最前面加上如下代碼:
SET CATALINA_OPTS=-server -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=5005
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
SpringBoot+ShardingSphereJDBC實現(xiàn)讀寫分離詳情
這篇文章主要介紹了SpringBoot+ShardingSphereJDBC實現(xiàn)讀寫分離詳情,通過用??MySQL??進行一主一從的主從復(fù)制展開全文內(nèi)容,需要的朋友可以參考一下2022-08-08Java引用傳遞實現(xiàn)方式以及與值傳遞的區(qū)別
這篇文章主要給大家介紹了關(guān)于Java引用傳遞實現(xiàn)方式以及與值傳遞的區(qū)別的相關(guān)資料,引用傳遞指在調(diào)用函數(shù)時將實際參數(shù)的地址直接傳遞到函數(shù)中,那么在函數(shù)中對參數(shù)所進行的修改,將影響到實際參數(shù),需要的朋友可以參考下2023-09-09