日常我们debug是经常用的,但是本地还好说,远程debug就有点难度,而且有时候必须要在预演,测试环境的服务器去debug,举个例子,需要https,公网,域名之类的,测试服务器这些有些是配置的,但是你自己本地开发肯定不会有这些,就需要你自己想办法了。

第一种情况就是你所用的是阿里云全家桶,或者是其他家的提供服务足够多的云服务商,你的公司又不差钱不墨迹,直接有啥用啥的话,实际上阿里云有一个toolkit的插件就可以,支持你镜像,kuberbets一大堆功能,他也可以做到远程调试。

远程连接服务器前置知识

但是如果没有去搞这些,甚至服务器都是自建的,那就要自己动手了。首先我们要理解一个概念JPDA(Java Platform Debugger Architecture)是Java平台调试体系结构,操作过程如下:

  • 1 本机和远程主机的两个 VM 之间使用 Debug 协议通过 指定的Socket 进行通信,传递调试指令和调试信息
  • 2 远程服务器作为被调试程序的远程虚拟机VM:作为 Debug 服务端,监听 Debug 调试指令。jdwp是Java Debug
    Wire Protocol的缩写
  • 3 本地调试程序的本地虚拟机VM:IDEA 中要先配置的 Remote Server,指定 Debug 服务器的Host:Port,以供
    Debug 客户端程序连接,这样服务调用就会调用到你本地,你就可以进行测试。

具体操作过程

配置IDEA中的remote,主要的配置如下:你要调用的module(就是项目入口的那个module),远程服务器地址,远程端口(这个远程端口不是服务器工程配置的端口,你可以理解为是JPDA的接口,用来监听远程服务debug)。

配置完上面主要的三个(毕竟这些都是你自己的,服务器多少,端口多少,那个项目都只有你知道),剩下的配置比较固定,比如通讯方式为socket,debug模式直接按照我的图抄就可以,attach是主动的获取debug的服务调用,listen是被动的,我一般是选择主动attach的,这样测试或者别人调起我debug的服务都会在我idea中展示出来,跟本地启动debug一样。

java socket 服务端显示远程主机拒绝现有连接 java远程服务器_远程服务器


配置远程服务器启动

由于我的是SpringBoot工程,服务器用的是Jenkins,我需要的只是在Jenkins的启动参数上加上如下:

-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005

记住这里的端口号设置是你的idea,如果你实在记不清楚没把握,idea实际上在配置remote的时候已经给你生成好命令了。

java socket 服务端显示远程主机拒绝现有连接 java远程服务器_远程服务器_02

启动远程服务器服务在启动本地远程debug

这里需要两个VM,本地的和远程的一个少不了,所以远程服务器启动项目这是一定的,但是本地怎么启动呢?

实际上你可以把第一步构建remote的过程,你可以理解为edit一个configuration,创建好了就会有一个项目在展示到启动项目那一块,如下:

java socket 服务端显示远程主机拒绝现有连接 java远程服务器_java_03


只不过你会发现run是灰色的,debug是绿色可用的,不用怀疑,这压根也用不到run,直接点击debng按钮去调试就好了,主动一点,要不然配置也白配置,让项目走起来,这样本地的VM就可以和远程的VM通讯了,否则你本地没有VM怎么联调debug。