使用IDEA实现远程代码DEBUG调试教程详解
我们在使用 IDEA DEBUG调试代码的时候,常常见到控制台会输出一句这样的话:「Connected to the target VM, address: '127.0.0.1:62981', transport: 'socket'」,所以即使代码不在本地运行,只要JVM打开调试模式,并且网络能够用过 socket 连接到JVM,使用 Debug 协议通过 Socket 通信就可以传递调试指令和调试信息。

IDEA配置启动环境(远程Debug服务器)
打开Intellij IDEA,在顶部靠右的地方选择”Edit Configurations”,进去之后点击左上角的+号,选择”Remote”,见下图,其中Name填写名称,可以随便起一个名字,host是你要远程调试代码的机器ip/hostname,port是调试监听端口,如果远端服务器已经开启了远程调试端口就填远程端口,如果没开,那么先选默认的5005端口,Use Module classpath 是选择远程运行的代码模块是哪个模块下的。

在Command line arguments for remote JVM,右侧选择JDK版本,这个是根据你远程服务器上运行的JDK版本选的,我这里选择 JDK5-8,就会给你一条命令,我这里得到的是:
-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005
这条命令就是启动远程调试的命令,有好奇的同学,咱们解释一下什么意思:
jdwp是Java Debug Wire Protocol的缩写
transport:有两种形式,分别是socket和shared memory,需要跨机器,只能用socket;
server:JVM是否需要作为调试服务器执行
suspend:是否调试客户端建立连接之后启动虚拟机。如果是y,则需要等调试端机器上的debugger开启后,程序才会开始运行。否则,程序启动时候不会挂起,直接运行。
address:监听端口5005作为调试端口
服务端调试环境
Jar包方式启动的程序
以Jar包方式启动的程序,例如SpringBoot,可以在启动的时候添加这个命令,例如:
java -jar -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 web.jar
Tomcat(war包)项目
以Tomcat(war包)运行的项目需要修改Tomcat启动脚本,Linux 的是 catalina.sh,Windows 的是 catalina.bat,将这个命令添加进去:
JAVA_OPTS="$JAVA_OPTS -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005"
服务器端的JVM参数添加好,等到程序启动,你就可以开始运行你电脑上的DEBUG了。如果连接失败,记得检查网络防火墙是否放行了端口。
探究原理
核心是JPDA(Java Platform Debugger Architecture)框架。IBM有非常详细的介绍:
关键摘抄如下
JPDA是JVM的调试标准,任何JDK都必须实现。
调试Java程序,本质是向JVM请求当前状态。这需要对JVM发送一定指令,设置一定回调。
JPDA的三个层次:Java 虚拟机工具接口(JVMTI),Java 调试线协议(JDWP)以及 Java 调试接口(JDI)。它们之间的角色图:
JVMTI(Java Virtual Machine Tool Interface):通向JVM的native的接口,处于体系最底层。所有的调试功能都需要该接口提供。是debug和profiler的接口,是线程分析、监听和代码覆盖率检查的基础。会有个紧耦合的Agent来实现JVMTI。该Agent的加载时间是出于JVM初始化早期或者运行时加载(对应于上文中的suspend参数)。
JDWP(Java Debug Wire Protocol):交互的通讯协议。定义了交互中的命令、回应数据和错误代码。不包含传输层具体实现。主要分为握手和应答两个阶段。
JDI(Java Debug Interface):对JDWP进行解析,为JDWP提供队列、缓存等服务。分为数据模块,将虚拟机上的所有数据、状态映射为Java的数据对象;链接模块,调试器向虚拟机发起链接,以获得各种状态,分为主动和被动形式。事件请求和处理模块。
由于JVM神一般的存在,使得Java的运行是先天可控的,因此其调试程序的开发,也远容易与C++。
类似工具:Apache harmony

商业用途请联系作者获得授权。
版权声明:本文为博主「任霏」原创文章,遵循 CC BY-NC-SA 4.0 版权协议,转载请附上原文出处链接及本声明。
相关推荐
猜你还喜欢这些内容,不妨试试阅读一下评论与留言
以下内容均由网友提交发布,版权与真实性无法查证,请自行辨别。- 2021-05-25 16:18:22
- Fuzhou, Fujian, China
- 回复
微信订阅号
扫码关注「任霏博客」微信订阅号- 大佬 引入jar包那里的 driver class 怎么选的?
- 我也遇到了这个问题,已经解决了,在此分享一下 1、宿主机也要创建kingbase的用户和用户组,并且要查看一下用户和用户组的ID(这个很重要) 2、把data目录的用户和用户组设置为kingbase 3、先不要把data路径挂载到宿主机上,这时就可以正常启动,启动后进入容器,查看一下容器内的kingbase的用户和用户组ID是多少,和第一步的ID是否一致,如果ID一致,那正常挂载目录就行;如果ID不一致,那就需要修改Dockerfile文件,在构建镜像时,修改容器内的用户和用户组ID,必须和宿主机的保持一致。然后重新构建镜像,就可以正常挂载宿主机目录了 4、其实直接修改宿主机的用户和用户组ID也是可以的,但是容器内的ID一般是1000,但是宿主机的这个ID很可能已经被占用了,无法修改,就只能修改容器内的ID
- 接口已经允许跨域请求,也就是说你可以在你的页面上调用,获取用户的公网 IP。 如果你还需要其他需求,可以提交 Issue 给我。
- V008R003C002B0320 这个对应的jdbc链接驱动你在哪里找到的?我也遇到了这个问题。
- WARNING: max_connections should be less than orequal than 10 (restricted by license) HINT: the value of max_connect is set 10 WARNING: max_connections should be less than orequal than 10 (restricted by license) HINT: the value of max_connect is set 10 kingbase: superuser_reserved_connections must be less than max_connections 我按照文档修改了以后,不知道如何重启。
- 然后把数字都改成 1 再启动。 如何重新启动?
- ksql: could not connect to server: No such file or directory Is the server running locally and accepting connections on Unix domain socket "/tmp/.s.KINGBASE.54321"
- 进入容器查看一下日志,是不是启动失败了,日志文件在:/opt/kingbase/logfile
- ksql: could not connect to server: No such file or directory Is the server running locally and accepting connections on Unix domain socket "/tmp/.s.KINGBASE.54321"?
- 先通过 docker exec -it 容器名/id /bin/bash 进入容器,然后在容器中使用 ksql 客户端进行连接数据库:/opt/kingbase/Server/bin/ksql -U system test
- 免费.ml域名10年委托合同到期被马里共和国收回域名经营权
- 从极狐Gitlab看各种中间件技术选型
- 时隔十年首次收到 Google AdSense 的付款
- ga域名被加蓬共和国从Freenom公司手中收回域名经营权
- Freenom 被 Meta(Facebook) 起诉导致暂停 .tk/.ga/.ml/.cf/.gq 等新域名注册
- 生花妙笔信手来 – 基于 Amazon SageMaker 使用 Grounded-SAM 加速电商广告素材生成 [1]
- github.renfei.net 不再完整代理 Github 页面改为代理指定文件
- 优雅的源代码管理(三):本地优雅的使用 Git Rebase 变基
- 优雅的源代码管理(二):Git 的工作原理
- 优雅的源代码管理(一):版本控制系统 VCS(Version Control System)与软件配置管理 SCM(Software Configuration Management)