IntelliJ IDEA遠程Debug Linux的Java程序,找問題不要只會看日志了(推薦)
1 前言
我們習慣于在本地開發(fā)的時候debug
,能快速定位與解決問題,那部署在服務器上是不是就沒有辦法了呢?只能通過查看日志來定位?
不是的,在遠端的服務器上,我們一樣可以debug
。
2 IDEA的debug
我們先來看一下在IntelliJ IDEA
直接debug
是怎樣的。
先準備一個簡單的Java
程序:
package com.pkslow.basic; import java.util.Map; public class RemoteDebug { public static void main(String[] args) { System.out.println("------------------start------------------"); System.out.println("get all the system environment"); Map<String, String> envs = System.getenv(); System.out.println("\nprint out the contains `HOME`"); System.out.println("------env HOME------"); envs.entrySet().stream() .filter(env -> env.getKey().contains("HOME")) .forEach(env -> { System.out.println(env.getKey() + ":" + env.getValue()); }); System.out.println("------------------end------------------"); } }
功能很簡單,獲取所有系統(tǒng)環(huán)境變量,并打印出含有HOME
字段的。
Debug
很簡單,直接點擊以下按鈕就可以:
相信大家都知道這一點,但應該很多人都不會注意,IDEA
究竟做了什么,為什么就可以調(diào)試了呢?我們看一下控制臺的日志就明白了:
/Library/Java/JavaVirtualMachines/jdk1.8.0_212.jdk/Contents/Home/bin/java -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:59313,suspend=y,server=n -javaagent:/Users/pkslow/Library/Caches/IntelliJIdea2019.3/captureAgent/debugger-agent.jar -Dfile.encoding=UTF-8 -classpath "/Library/Java/JavaVirtualMachines/jdk1.8.0_212.jdk/Contents/Home/jre/lib/charsets.jar:" com.pkslow.basic.RemoteDebug
簡化一下,不重要的參數(shù)去掉:
java -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:59313,suspend=y,server=n com.pkslow.basic.RemoteDebug
這就是可以Debug
的原因,利用了Java Agent
原理。這個功能很強大,類似一個AOP
,代理了Java
程序,可以利用它進行調(diào)試、熱部署等。
3 調(diào)試本地程序
我們先試試如何可以調(diào)試本地程序,不是直接在IDEA
上調(diào)試。先要編譯出class
文件RemoteDebug.class
,然后按package
結(jié)構(gòu)放好。我通過mvn clean compile
來編譯。
啟動程序,在target/classes/
目錄執(zhí)行:
$ java -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:50050,suspend=y,server=y com.pkslow.basic.RemoteDebug Listening for transport dt_socket at address: 50050
然后程序就會等待調(diào)試客戶端的連接,不會往下執(zhí)行。
配置IDEA
以進行調(diào)試:
配置完成保存后,點擊debug
就可以了:
程序已經(jīng)進入debug
模式:
我們已經(jīng)執(zhí)行到了其中一行,現(xiàn)在看看服務端:
與IDEA
是同步的,并且確實已經(jīng)控制了服務端Java
的執(zhí)行。
4 遠程調(diào)試Linux Java程序
先把程序部署在Linux
上:
$ scp -P 22 ./com/pkslow/basic/RemoteDebug.class root@xxx.xx.xx.xxx:/root/remoteDebug/com/pkslow/basic/ RemoteDebug.class 100% 2572 282.5KB/s 00:00
通過以下命令在服務端啟動程序,這里調(diào)試端口改為9999
,因為部分端口在遠程服務器并沒有開啟:
java -agentlib:jdwp=transport=dt_socket,address=9999,suspend=y,server=y com.pkslow.basic.RemoteDebug
本地電腦IDEA
配置如下:
開始debug
,正??刂屏诉h程服務端的Java
:
服務端的實時執(zhí)行情況:
讓程序執(zhí)行完如下:
$ java -agentlib:jdwp=transport=dt_socket,address=9999,suspend=y,server=y com.pkslow.basic.RemoteDebug Listening for transport dt_socket at address: 9999 ------------------start------------------ get all the system environment print out the contains `HOME` ------env HOME------ JAVA_HOME:/root/jdk1.8.0_131 HOME:/root ------------------end------------------
5 總結(jié)
本文一步步探索如何進行調(diào)試遠程的服務器,這在出現(xiàn)問題時定位還是非常有用的。畢竟可以實時看到服務端運行環(huán)境。
到此這篇關于IntelliJ IDEA遠程Debug Linux的Java程序,找問題不要只會看日志了的文章就介紹到這了,更多相關IDEA遠程Debug Linux的Java程序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解Spring Boot 自定義PropertySourceLoader
這篇文章主要介紹了詳解Spring Boot 自定義PropertySourceLoader,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05如何使用JWT的SpringSecurity實現(xiàn)前后端分離
這篇文章主要介紹了使用JWT的SpringSecurity實現(xiàn)前后端分離,登錄成功需要返回json數(shù)據(jù)登錄失敗需要返回json數(shù)據(jù)權(quán)限不足時返回json數(shù)據(jù)未登錄訪問資源返回json數(shù)據(jù),需要的朋友可以參考下2024-08-08Java中數(shù)組與集合的相互轉(zhuǎn)換實現(xiàn)解析
這篇文章主要介紹了Java中數(shù)組與集合的相互轉(zhuǎn)換實現(xiàn)解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-08-08