文章目录
-
- 一、前期准备
-
- [1. 检查IDE版本是否支持](#1. 检查IDE版本是否支持)
- [2. 服务器需要开通SSH服务](#2. 服务器需要开通SSH服务)
- 二、Pycharm本地链接服务器测试
-
- [1. 配置服务器python解释器](#1. 配置服务器python解释器)
- 三、使用内网穿透实现异地链接服务器开发
-
- [1. 服务器安装Cpolar](#1. 服务器安装Cpolar)
- [2. 创建远程连接公网地址](#2. 创建远程连接公网地址)
- 四、使用固定TCP地址远程开发
本文主要介绍如何使用Pycharm进行远程开发,并实现在家远程与公司服务器资源同步。
新版本Jetbrains 系列开发IDE(IntelliJ IDEA ,PyCharm ,GoLand )等都支持远程使用服务器编译,并且可以通过SFTP同步本地与服务器项目代码。
这样做的好处是**我们只要连接上服务器就能开始干活儿,不用折腾环境,**不占用个人笔记本资源,最重要的是不用忍受笔记本的烂风扇噪音。
接下来我来教大家如何配置实现在家远程利用公司服务器资源开发:
data:image/s3,"s3://crabby-images/2865b/2865b137f019e3d3c3c1f9552ed0ec877ae308f3" alt=""
一、前期准备
1. 检查IDE版本是否支持
本文以Pycharm 举例,IntelliJ IDEA操作方式相同。
确认您安装的PyCharm是社区版还是专业版 ,只有专业版才支持远程开发功能。
在这里查看软件版本:工具栏help->about
data:image/s3,"s3://crabby-images/c898e/c898e60f8bc3ce93f3b9cb68bc53a549899ac033" alt=""
显示 Professional Edition,即为专业版。
2. 服务器需要开通SSH服务
执行:
shell
sudo systemctl status sshd
data:image/s3,"s3://crabby-images/f4de2/f4de28ebae4df2bada49fe47c1fe56e5a2c38cb3" alt=""
active表示已开通
二、Pycharm本地链接服务器测试
1. 配置服务器python解释器
找到工具栏的 [File] -> [Settings],打开以下设置弹窗,搜索interpreter找到[Python interpreter]设置项
data:image/s3,"s3://crabby-images/29be1/29be1b7e88bd6f2464a342908bebcd45d61210bb" alt=""
点击Add Interpreter,选择On SSH
data:image/s3,"s3://crabby-images/08635/08635bbed5c6bbc4e248e56dba0a510e1ba52d88" alt=""
将实例SSH指令中的Host、Port与Username进行匹配和填写(Username均为root,Host和Port查看自己实例的SSH指令)
data:image/s3,"s3://crabby-images/af9e1/af9e1f4dd94a95bd81abc300ddf63dded45fef57" alt=""
输入服务器登陆密码:
data:image/s3,"s3://crabby-images/46d91/46d9133ad0616f860e3223462da51ab739cb1a80" alt=""
继续下一步,直到看到 completed 字样,再点下一步。
data:image/s3,"s3://crabby-images/c9d8c/c9d8cc8893f671d83ef83ae18b487f597dcfd51a" alt=""
选择System Interpreter(选择服务器的代码解释器),选择服务器的远程Python解释器路径(如果您安装了其他Python或虚拟环境则根据实际情况填写)
data:image/s3,"s3://crabby-images/e81e8/e81e8286c7a9ad10f37f37c6b4edb75b15c703b8" alt=""
配置项目路径,意思是本地项目和远程实例中的哪个目录进行关联,这里设置为我演示项目的目录(不建议使用默认的/tmp目录)
选择好自定义同步项目文件夹,点击文件夹图标:
data:image/s3,"s3://crabby-images/1b5a5/1b5a5b919146c676a2e36c914aa9802ce322905a" alt=""
弹窗内左侧为本地项目路径,右侧为服务器项目路径,可以自行修改:
data:image/s3,"s3://crabby-images/fd26b/fd26b4dd75d0b82287baae14678791e43cb63d82" alt=""
我修改的远程路径为:/root/projects/pythonlearn,点 ok
data:image/s3,"s3://crabby-images/d9619/d9619d71384065217ad2de7241b9b9b52d16c9c7" alt=""
检查一下远程服务器的解释器和同步路径,点 Create
data:image/s3,"s3://crabby-images/aa009/aa0099cb3686493e517bb1735230b7c143deaf29" alt=""
如果配置均无误PyCharm会配置一下,之后我们在本机项目最下边可以看到 SFTP 字样和服务器信息,说明我们的配置成功,此时我们不光使用服务器编译代码,项目还能与服务器同步。
我链接服务器后同步出的数据如下:
data:image/s3,"s3://crabby-images/ad0ac/ad0acc9eca89dbfc7be494085ad589fe8b8032c2" alt=""
此处我们在本地测试成功,但是这样配置的意义就是可以实现异地使用服务器的资源开发,这里我们**需要将SSH时使用的本地IP映射为公网TCP地址,才能实现异地开发。**这样我们只需本地编写代码,远程到服务器编译并同步代码。
三、使用内网穿透实现异地链接服务器开发
1. 服务器安装Cpolar
本地测试完成后,我们需要在服务器上安装cpolar内网穿透工具,通过cpolar 转发本地端口映射的公网地址,我们可以很容易实现远程访问。下面是安装cpolar步骤:
cpolar官网地址: https://www.cpolar.com
- 使用一键脚本安装命令
shell
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash
- 向系统添加服务
shell
sudo systemctl enable cpolar
- 启动cpolar服务
shell
sudo systemctl start cpolar
cpolar安装成功后,在外部浏览器上访问Linux 的9200端口即:【http://服务器的局域网ip:9200】,使用cpolar账号登录,登录后即可看到cpolar web 配置界面,结下来在web 管理界面配置即可
data:image/s3,"s3://crabby-images/4909c/4909cd728604521382c020d58253eca1b6de3ea3" alt=""
Ubuntu18及Centos7之前的系统,需要使用手动安装Cpolar,详见:
Linux手动安装Cpolar方法 - cpolar 极点云
2. 创建远程连接公网地址
登录cpolar web UI管理界面后,点击左侧仪表盘的隧道管理------创建隧道:
data:image/s3,"s3://crabby-images/816a8/816a866611d23e5e42b0e57dcf08b10a37789f72" alt=""
- 隧道名称:可自定义,注意不要与已有的隧道名称重复
- 协议:tcp
- 本地地址:22 (本地ssh默认端口)
- 域名类型:临时随机TCP端口
- 地区:选择China
点击创建
创建成功后,打开左侧在线隧道列表,查看刚刚创建隧道后生成的tcp地址,这个地址就是公网连接地址,接下来使用这个地址:1.tcp.cpolar.cn:20747 ,替换我们的本地地址。
data:image/s3,"s3://crabby-images/459ab/459ab892c0af961eb1a60cf92f9b924963ff5e13" alt=""
我们再次回到编译器设置界面, 点击Add Interpreter,选择On SSH
data:image/s3,"s3://crabby-images/08635/08635bbed5c6bbc4e248e56dba0a510e1ba52d88" alt=""
找到[Python interpreter]设置项,选择Existing,修改Python编译器地址:
data:image/s3,"s3://crabby-images/a02bb/a02bbb73fdff5c8ff6bd14494deca269b232b5c2" alt=""
选择后边是 agent 这个 sever选项
data:image/s3,"s3://crabby-images/8ec8f/8ec8f53bae185157d7f22e83b4a5d80bc0a8d5b2" alt=""
点 管理
data:image/s3,"s3://crabby-images/91cad/91cadbe26e908086e5457b89f42c3c0124c69f6d" alt=""
修改本地地址为公网TCP地址,修改端口号。
data:image/s3,"s3://crabby-images/03ae3/03ae3c7d303b040f611b16bb376636f4a9ef581d" alt=""
修改为:
data:image/s3,"s3://crabby-images/47bb9/47bb920a401dd44fe983b8f2a72954afe91f61c6" alt=""
点击Apply部署,点 ok,自动跳转为:
data:image/s3,"s3://crabby-images/3e8dd/3e8dd7bfbbf25a4a6ad9d335ab6807f37ec0f67f" alt=""
点 ok
data:image/s3,"s3://crabby-images/cc2b9/cc2b9071ed835743cd7ef69b8284f4c421efd5c3" alt=""
输入服务器登陆密码:
data:image/s3,"s3://crabby-images/9b2cf/9b2cf978a2c02e1b3279393bb11b3856f260a540" alt=""
配置完毕,点Next
data:image/s3,"s3://crabby-images/7df69/7df69d13de47ecb4b792001823d248cd6776c506" alt=""
我们可以看到已经链接成功,可以看到编译器路径和项目保存路径,点 create:
data:image/s3,"s3://crabby-images/72290/7229071c3ff61fbba273e14c64370c0a083b1966" alt=""
等待一会加载:
data:image/s3,"s3://crabby-images/f0aae/f0aaecb31b4934bef37d0c206e3e37835367fa48" alt=""
此时Python编译器处已经显示我们配置的公网地址,点Apply,就配置完成。
data:image/s3,"s3://crabby-images/d967d/d967d1823464c6b08b5ec709e69a7b06f8267885" alt=""
项目页面左下角已经显示我们编译器的路径,此时我们编译代码使用的就是服务器编译器,运行完毕后结果返回至Pycharm。
data:image/s3,"s3://crabby-images/737d0/737d0091d728c1f3aa5b0a1a90217bf04f1b4b84" alt=""
小结
为了方便演示,我们在前述过程中使用了Cpolar生成的TCP地址隧道,其公网地址是随机生成的。
这种随机地址的优势在于建立速度快,可以立即使用。然而,它的缺点是网址是随机生成,这个地址在24小时内会发生随机变化,更适合于临时使用。
我一般会使用固定TCP域名,原因是我希望每天打开开发工具直接上手工作,不用这配置一下那配置一下,接下来我教大家如何固定TCP地址:
四、使用固定TCP地址远程开发
访问官网控制面板,保留TCP:
Cpolar - secure introspectable tunnels to localhost
保留一个固定tcp地址,登录cpolar官网,点击左侧的预留,找到保留的tcp地址,为远程服务器连接保留一个固定tcp地址:
- 地区:选择China VIP / China VIP Top。
- 描述:即备注,可自定义
点击保留
data:image/s3,"s3://crabby-images/5c1e5/5c1e5b2d15fdde255e4d00467bf38223ed6567f7" alt=""
地址保留成功后,系统会生成相应的固定公网地址,将其复制下来:
data:image/s3,"s3://crabby-images/825cc/825cccc97d832c6d30d9ac819c68f9c178c933eb" alt=""
打开cpolar web ui管理界面,点击左侧仪表盘的隧道管理------隧道列表,找到我们上面创建的TCP隧道,点击编辑
data:image/s3,"s3://crabby-images/77406/77406a7cac0b5e2156bbdc75606c4cca5e412e1f" alt=""
选择 固定TCP端口:
data:image/s3,"s3://crabby-images/4dba2/4dba2f7194378d26eadda0e7ff5e75885d2bae3f" alt=""
修改隧道信息,将保留成功的固定tcp地址配置到隧道中
- 端口类型:修改为固定TCP端口
- 预留的tcp地址:复制粘贴官网保留成功的地址
点击更新
隧道更新成功后,点击左侧仪表盘的状态------在线隧道列表,可以看到公网地址已经更新成为了固定TCP地址。
data:image/s3,"s3://crabby-images/8a6bc/8a6bcb7cc7701d5bc2e111497815ca048e75739a" alt=""
我们仍然重复之前的操作,将原来的随机TCP地址替换为固定TCP地址:
找到工具栏的 [File] -> [Settings],选择Existing,修改Python编译器地址:
data:image/s3,"s3://crabby-images/a8b21/a8b2135c5d47636aed86957115edca370f0e0ac4" alt=""
按照如下方法填写我们固定好的TCP地址和端口号:
data:image/s3,"s3://crabby-images/5b405/5b4057bc9b73f81b381b5dac717f42f2bd41f268" alt=""
点击Apply后,点 ok
data:image/s3,"s3://crabby-images/01d27/01d274da7bde01d1683f3c177cc8903b55fe6ad9" alt=""
点 Next
data:image/s3,"s3://crabby-images/4edf1/4edf11078d4af55efe4f32605a8e477077d5737f" alt=""
点 ok
data:image/s3,"s3://crabby-images/a0024/a0024cd37c2cf890b5aeee318354d40c21065195" alt=""
输入服务器登陆密码
data:image/s3,"s3://crabby-images/f5630/f5630fedbdd7744c256df9c4df14c0a3144ad1cd" alt=""
配置完毕,点 Next。
data:image/s3,"s3://crabby-images/ebd76/ebd76efeff2d619af22083097597d66c1fe73de7" alt=""
这里我们看到,已经自动查到我们服务器中编译器路径和项目保存路径;点 create。
data:image/s3,"s3://crabby-images/0441e/0441ef3fd85f52b8833a3b59c6a8b1b3eeffc184" alt=""
点Apply部署,点 ok
data:image/s3,"s3://crabby-images/3d5f4/3d5f46e37bedd1ae8b1c3fa0b4a6b10a53501177" alt=""
此时我们可以看到左下角已经显示使用我们固定地址的Python编译器:
data:image/s3,"s3://crabby-images/948d2/948d21eae321833be1cb9b480379384083979d22" alt=""
本教程最终效果已经达成。我们已经能够使用永久固定地址来远程操作服务器中的Python编译器并将运行结果返回到Pycharm,代码修改还能通过这个TCP地址同步,这样我们就可在任意地点远程使用服务器的强大算力来编译各种复杂的项目而不占用本地资源!