体验IntelliJ IDEA的远程开发(Remote Development)

本篇概览

  • IDEA的远程开发功能,可以将本地的编译、构建、调试、运行等工作都放在远程服务器上执行,而本地仅运行客户端软件进行常规的开发操作即可,官方给出的逻辑图如下,可见通过本地的IDE和服务器上的IDE backend将本地电脑和服务器打通,实现了远程开发的效果

image-20220319174602803

  • 实际体验中,感觉就像平常的IDEA本地开发,但其实繁重的任务都交给了服务器去做,这对性能较差的本地电脑来说,以前跑不动的应用,如今凭借强大的服务器也能丝滑运行了

  • 今天就来一起实战IDEA远程开发,让破旧的本地电脑也能流畅的编译运行Java应用

  • 文章由以下几段组成:

  1. 环境信息一览
  2. 准备服务器
  3. IDEA远程连接
  4. 重新设置工程的根目录
  5. 端口转发
  6. 其他要注意的地方

环境信息一览

  • 以下是我这边本次实战的环境信息,可作为参考
  1. IDEA:2021.3.2 (Ultimate Edition)
  2. 本地电脑操作系统:macOS Montery(12.3)
  3. 服务器:Ubuntu 20.04 LTS(4核8G)

准备服务器

  • 一台Linux服务器是远程开发必须的,自己内网的、租用云服务厂商的都可以

  • IDEA会自动在服务器上安装所需的服务,咱们无需提前准备什么,唯一要求是可以通过SSH登录此服务器

  • 欣宸的服务器是腾讯云轻应用服务器,在官网租用的,如下图,4核8G,一年两百多,感觉挺划算

    在这里插入图片描述

  • 接下来要在服务器上把开发用的代码准备好,我这里是将自己github仓库下载到服务器上,代码存放在这里:/home/ubuntu/jetbrains-workspace

<span style="color:#393939"><span style="background-color:#faf7ef"><code class="language-java">ubuntu<span style="color:#2b91af">@VM</span>-<span style="color:#880000">12</span>-<span style="color:#880000">12</span>-ubuntu:~/jetbrains-workspace$ git clone https:<span style="color:#008000">//github.com/zq2599/blog_demos.git</span>
Cloning into <span style="color:#a31515">'blog_demos'</span>...
remote: Enumerating objects: <span style="color:#880000">14559</span>, done.
remote: Counting objects: <span style="color:#880000">100</span>% (<span style="color:#880000">1097</span>/<span style="color:#880000">1097</span>), done.
remote: Compressing objects: <span style="color:#880000">100</span>% (<span style="color:#880000">350</span>/<span style="color:#880000">350</span>), done.
remote: Total <span style="color:#880000">14559</span> (delta <span style="color:#880000">846</span>), reused <span style="color:#880000">818</span> (delta <span style="color:#880000">703</span>), pack-reused <span style="color:#880000">13462</span>
Receiving objects: <span style="color:#880000">100</span>% (<span style="color:#880000">14559</span>/<span style="color:#880000">14559</span>), <span style="color:#880000">110.29</span> MiB | <span style="color:#880000">3.05</span> MiB/s, done.
Resolving deltas: <span style="color:#880000">100</span>% (<span style="color:#880000">4714</span>/<span style="color:#880000">4714</span>), done.
</code></span></span>

IDEA创建远程连接

  • 服务器端准备完毕后,可以开始本地电脑的远程连接操作了

  • 打开IDEA,如下图,选择New Connection

image-20220319101341382

  • 输入IP地址,账号密码

    在这里插入图片描述

  • 按要求输入密码,远程连接成功后,指定工作目录(Project directory),我指定的是代码仓库所在目录,然后点击右下角的Download and Start IDE

    在这里插入图片描述

  • 远程服务器开始下载后端应用,这是用于支持远程开发的服务

    在这里插入图片描述

  • 等待下载完成后,就会多出一个名为JetBrains Client的应用,并且已经打开,如下图红框,这就是将来做远程开发的本地工具了

image-20220319155712297

  • JetBrains Client界面如下,看起来像是IDEA,可以看到刚才在服务器下载的整个仓库的内容,和在本地打开没什么区别,Terminal打开的也是服务器目录,修改代码时改动的也是服务器上的代码

    在这里插入图片描述

  • 还剩一个问题:如上图所示,此仓库中并不只有一个java项目,而是有几十个文件夹,每个文件夹下都是个独立的工程(有的是gradle,有的是maven),如果我现在只想修改其中的一个(例如上图红框中的quarkus-tutorials),并编译运行它,应该怎么操作?接下来就解决此问题(这是IDEA的操作,并非远程连接的问题)

重新设置工程的根目录

  • 接下来要解决的问题是:IDE远程打开的文件夹里有多个工程,我只想打开其中的一个maven工程进行开发和调试

  • 顶部菜单选择"File" -> "Project structure..."

image-20220319112034629

  • 点击下图红框位置的X符号,会删除当前内容根目录(Content Root)

    在这里插入图片描述

  • 点击下图红框中的加号,重新添加内容根目录(Content Root)

    image-20220319112529312

  • 选择用于开发的文件夹即可

image-20220319112753819

  • 选择完毕后,终于见到熟悉的目录结构

image-20220319113217415

  • 您可能会觉着这一段的操作是多此一举:只要在远程连接的时候设置工作目录是quarkus-tutorials就行了,没必要这么麻烦,您说的没错,在远程连接的时候确实可以直接指定目录,但是如果此刻使用的是Jetbrains的space,那里无法直接指定目录,只能直接打开

作为maven工程运行

  • 关于服务器的JDK,如果装了,请按照下图位置去选择,如果没有安装,按照下图进行远程下载即可

image-20220319113425220

  • 此刻,IDE并未识别到这是个maven工程,需要打开pom.xml,然后在右键菜单中选择Add as Maven Project,如下图红框

image-20220319115056364

  • 等待项目加载和更新完成后(生成索引时间较长,我这边半小时),终于见到了熟悉的maven项目页面,可见和用IDEA时候并无区别

    image-20220319121939312

  • 试试maven的单元测试,如下图,和使用IDEA并无区别,顺利执行

image-20220319153835111

端口转发

  • 开发web应用时,启动应用后,访问远程IP地址和端口可能比较麻烦(有的服务器涉及到安全问题不轻易开端口),此时JetBrains Client提供的端口转发功能非常实用
  • 端口转发配置方式如下图,这样我访问本机的8080端口时,请求就会转到服务器的8080端口

image-20220319121633425

  • 启动应用试试,我的应用是个普通web应用,启动后监听8080端口,然而我并没有给服务器开通8080端口到外网,如下图,从本地可以访问成功

    在这里插入图片描述

其他要注意的地方

  • 退出的时候,会提示是否关闭远程服务,请自行选择,我选择的是Close and Keep Running

image-20220319104230126

  • 如果嫌每次输入密码麻烦,就在idea中保存起来

image-20220319104609627

  • 下次再打开时就会出现之前的记录,点击即可进入

    在这里插入图片描述

  • Git提交功能也可以正常使用:本地的提交其实是将服务器上的代码提交到Github

    在这里插入图片描述

  • 最后别忘了去插件管理页面安装常用插件

  • 至此,IDEA远程开发的实际体验已经完成,希望本文能给您一些参考,助您搭建一个稳定高性能的开发环境

### IntelliJ IDEA SSH 远程连接配置教程 #### 一、准备工作 为了确保能够顺利地通过SSH协议连接至远程服务器,在开始之前需确认已获取目标机器的IP地址、登录用户名以及相应的私钥文件或密码。 #### 二、设置远程开发环境 在IntelliJ IDEA中实现远程开发功能,可通过JetBrains Gateway工具来完成。当指定主机名与用户名并提交验证信息(如密钥或密码),Gateway负责建立安全shell (SSH)链接,并自动检测是否存在可用的IDE后端;如果不存在则会从官方站点下载最新版进行部署[^1]。 #### 三、具体操作流程 进入IntelliJ IDEA界面后按照如下路径找到远程开发选项:`File -> Remote Development`。随后点击`New Connection`按钮新建一个连接实例。在此过程中需要准确无误地填入必要的身份认证资料,包括但不限于服务器地址、账户名称等基本信息。接着依据提示输入正确的访问凭证——这可能是预先设定好的秘钥或者是简单的字符型密码。最后一步是从给定列表里挑选合适的IDE版本号及定义好项目的存储位置[^2]。 ```bash # 打开终端测试连通性 ssh username@remote_host_ip_address ``` #### 四、开启SSH终端 一旦上述步骤顺利完成,意味着已经成功建立了通往远端计算机的安全通道。此时可以尝试通过菜单栏中的`Open an SSH Terminal`选项打开内置命令行工具进一步检验网络状况或是执行其他初始化脚本工作。 #### 五、处理特殊场景下的需求 对于某些特定场合下可能涉及到更复杂的网络架构,比如企业内部网环境中想要借助中间跳板机作为中介来进行间接性的程序调试活动,则可以通过构建SSH隧道的方式来达成目的。这种方式允许开发者绕过防火墙限制从而获得更加灵活的操作权限[^4]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值