最近和某财务软件接口对接,因为各种客观事实问题得用 idea 的远程调试功能,这下问题就来了
1. 直接说最终解决方案
不要使用 windows 的 idea 进行远程调试,Linux 或者 Mac 都可以,我是用的 Mac 14.3 (23D56)。
升级 Mac 自带Rsync 和 SSH,idea 配置即可
2. 再来说说一路上遇到的问题
在 windows 遇到的问题
- windows 下是用 SFTP 同步文件非常慢,且只是能启动,每次修改代码需要重新上传重新启动,常常还遇到服务器的 spring 进程关不掉本地调试卡死的情况。
- 好的,那我开始尝试 Rsync,众所周知Rsync 只有 Linux。我尝试是用 Cygwin64 下载 Rsync。Windows上安装rsync
https://blog.csdn.net/qq_53614788/article/details/134492367
- 好的我在 idea 中配置 SSH和 Rsync,正当我以为马上就能开始 debug 的时候怎么都报错找不到 spring 启动类的 class path。
抽象问题找GPT 不如自己找问题 - 我通过各种方式包括读大量日志的时候发现一个大坑,windows的路径在 rsync 同步到 Linux 上的时候会遇到路径转义错误,坑爹ClassNotFoundException when running on remote with rsync
https://youtrack.jetbrains.com/issue/IDEA-281731/ClassNotFoundException-when-running-on-remote-with-rsync
- 于是我尝试过网上的各类解决方法,可是使用下来体验极差包括不限于无法热更新,无法关闭 ssh,idea 由于服务器上的进程关闭卡死http://idea run on target ssh rsync 同步异常问题
https://www.jianshu.com/p/23382bf1f95f
- 于是我尝试在 WSL2 的环境中远程调试服务器,结果发现 idea 的 Debug 网络模式和端口配置还有坑在WSL2中利用gradle构建项目时出现:Could not connect to the Gradle daemon. 的解决方案
https://blog.csdn.net/Danshui_liuhen/article/details/135896701
- 我甚至尝试过通过JetBrains Gateway, ssh 远程调试本地 WSL 再远程 Debug 同步到服务器,体验都极差,于是我拿出了我的 MAC 来尝试
在 Mac 下的尝试
- 在 mac 下我轻松的配置好了 idea 的远程调试,一运行又出了 ClassNotFoundException
- 我就奇了怪,mac 怎么会出现和 Windows 一样的错误,难道还是路径问题?我的直觉告诉我肯定不是,因为这不符合逻辑;
- 我看了 rsync 的日志,结果出现了 error 225,找了半天原因,结果发现坑爹的 Mac Rsync 是 06 年的老版本
rsync --version // rsync version 2.6.9 protocol version 29 // ...
- brew 仓库也是老版本,那么需要自己动手了Updating `rsync` on macOS, so you're not stuck with 14 year old software
https://dev.to/al5ina5/updating-rsync-on-macos-so-you-re-not-stuck-with-14-year-old-software-1b5i
- 我信心满满的运行,结果还是不行 rsync 出现了 error 127。那明显就是 ssh 的问题了,于是乎我开始安装 openssh
brew install openssh
- 行吧 继续安装 xcode
xcode-select --install
- 最后配置一下新的 path