前言
开发新功能时,经常会遇到在本地环境运行没问题,但是部署到了 Linux 服务器上跑的时候就出现问题这种情况;还有一种情况是需要定位线上问题,这两种情况以前的做法就是加 log 日志输出,总是不能精准定位问题所在,如果能够像本地环境一样调试代码,那这个问题也就迎刃而解了。
开始之前
本文介绍 IDEA 与 Tomcat 的远程调试,且笔者在日常工作当中也是这么做的,网上很多都是互相抄袭,没有经过验证的伪原创,让人不快。
一、添加运行项
IDEA 添加远程调试项
填写服务器 IP ,端口使用默认的即可,复制第二行参数
二、修改服务器中的 Tomcat 配置
连接远程服务器,进入 Tomcat 根目录下的 bin
目录,修改 catalina.sh
文件
定位到 108 行左右,找到 cygwin=false
这一行,
在这一行的前一行添加
JAVA_OPTS=""
然后将从 IDEA 中复制的那串参数粘贴到双引号之间,保存退出。
然后启动 Tomcat,如果 Tomcat 是已经启动的话,必须要重启一下。
三、调试环境修改
为了调试方便,需要暂时关闭掉防火墙,否则可能无法连接。
四、IDEA 远程调试
回到 IDEA,点击 Debug 按钮,启动刚才添加的 Remote,如果以上没有配置错,那么控制台将打印出
此时就和本地调试一样打断点调试就行了
五、解决IDEA 无法连接远程 Tomcat
如果提示无法连接,如下图
则检查以上配置是否正确,确认都正确的话,可能是服务器防火墙的原因导致,需要关闭防火墙。
如果服务器是阿里云的,还需要配置 ECS 服务器的安全组,开放 5005
远程调试端口。 详见第八条
六、解决断点不生效
注意:
启动 Remote 的 Debug 之后,需要等待断点变成如下图时,再去访问接口;如果断点中间没有出现对号,说明断点还未生效,需要等待一会儿。
如果有时候死活也没法断点,就把服务器上的 Tomcat 重启一下试试!
七、其他问题
因为在 catalina.sh 中添加了远程调试的参数,导致使用 tomcat 的 bin/shutdown.sh 时,可能无法完全停止服务器。可以直接 kill 掉服务器,如果不再进行远程调试,最后把远程调试参数注释掉重启。
八、阿里云 ECS 安全组设置
进入 ECS 控制台,点击安全组
然后选择 创建安全组
然后配置该安全组的规则
点击公网入标签,再点击右上角 添加安全组规则
授权对象 填写你的 ip 地址即可。
添加完安全组之后,进入 ECS 实例
选择右侧 加入安全组,选择加入刚才添加的安全组即可。