开发调试过程中,有些场景无法在本地完成,譬如调试微信开发相关功能。由于微信要求回调地址必须是认证过的域名,本地显然无法满足这个要求,所以远程调试就可以派上用场。

Tomcat远程调试的配置主要有两种方式,一种基于JAVA_OPTS,另一种则是直接使用JPDA接口。

经典的OPTS配置如下:
JAVA_OPTS="$JAVA_OPTS -server -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8787"

其中,-server指定server模式,transport模式为socket通信,非阻塞,端口8787。

随着大家对JVM的认识越来越深入,JPDA的方式逐渐替代了传统的OPTS方式。

简单说说JPDA。JPDA全称是Java Platform Debugger Architecture,即java平台调试体系,由三个相对独立的模块或者层次组成,这三个层次分别是JVMTI(Tool Interface),JDWP(调试协议)以及JDI(调试接口)。JVMTI是5.0之后推出,用来替代之前的JVMPI及JVMDI,三者关系示意图如下。

Tomcat远程调试_第1张图片

Tomcat远程调试_第2张图片

JPDA方式远程调试和OPTS的区别是,通过启动参数(原生的支持)实现。

./catalina.sh jpda start

需要注意的是,JPDA的默认地址是“localhost:8000”, 需要将JPDA_ADDRESS进一步修改,在catalina.sh中,添加如下内容:

export JPDA_ADDRESS=8000

至此,我们就可以开始本地的服务器调试了。

以IDEA为例,添加Remote应用:

Tomcat远程调试_第3张图片

示例中我们修改了默认端口从8000到9081,这个需要确认服务端防火墙已开启,所以在联调前,telnet 端口是否开通。

最后,远程调试,需要确保本地代码和服务器的版本一致,否则会出现代码错位的情况,让调试效果大打折扣。