type
status
date
slug
summary
tags
category
icon
password
Property
Mar 4, 2024 12:13 PM
之前就有听说 Github 将推出在线 IDE,一搜索发现很多结果。
data:image/s3,"s3://crabby-images/0b415/0b415336605eee58d0e2567895c5cda11360dc25" alt="notion image"
现在 Github 的在线 IDE 发布一段时间了,官方命名为:Github Codespaces(点击可以申请),今天我们就来体验一下。
基础体验
在这里,我就拿本博客的仓库来简单体验一下 Github Codespaces。
创建 IDE
在 Clone 的按钮选择
data:image/s3,"s3://crabby-images/01f43/01f432cb78a4c7aa68f8607c6137916f93549d68" alt="notion image"
进入之后会列出已有的 IDE 列表,没有的话点击下面的新建就是了。
data:image/s3,"s3://crabby-images/daad1/daad1a5956b8dfecf7ef1ed36b4c801943f4059b" alt="notion image"
进入 IDE
开始进入是在初始化,然后就是同步一些配置,会发现在 Vscode 的配置和插件扩展都会被同步过来(当然,前提是你本地的 VSC 和自己的 Github 绑定起来,并且同步配置)。
data:image/s3,"s3://crabby-images/22fb7/22fb7bed67011f854b455cb0fbb311a6e9c96192" alt="notion image"
image
data:image/s3,"s3://crabby-images/2867d/2867dad5f4087b23dbbf2780345eac27b4bd5df3" alt="notion image"
并且可以看到,IDE 可以自动识别 package.json 安装依赖,进来就自动安装好了。
data:image/s3,"s3://crabby-images/7f042/7f0422744f908454a1db5fcb34826b22d0805c5a" alt="notion image"
点击查看日志还可以查看初始化的日志。
data:image/s3,"s3://crabby-images/733ab/733ab4320abbda545999a9dbf1355c88f8e4479c" alt="notion image"
image
基本使用
预装基础环境
简单的几行代码 我们可以发现 IDE 已经预装了 node、docker、npm、git、python 等等基础开发环境。
data:image/s3,"s3://crabby-images/86492/864922082e6981e3398afeb40853330915382361" alt="notion image"
image
启动项目
首先 全局安装 Hexo
yarn global add hexo
,再启动项目yarn d
.因为 github 的环境在外面,因此安装速度还是很快的,纵享丝滑。
data:image/s3,"s3://crabby-images/a38a8/a38a8030148797ab8c183e4e983b419586f70f24" alt="notion image"
image
外部端口的打开
如果我们的页面需要启动本地端口,IDE 也会提示出来有外部端口。
data:image/s3,"s3://crabby-images/e87da/e87da87421fe55e28858afdaaecd5c4aa88e975d" alt="notion image"
image
我们也可以在
Remote Explorer
看到全部的端口映射情况data:image/s3,"s3://crabby-images/762da/762daed2a4501c7c719a5c31ac8d5af9d514c165" alt="notion image"
我们点击在浏览器打开,然后就可以看到页面了。
data:image/s3,"s3://crabby-images/482da/482dad0cddc2bf1c1ae60b8b458ff3e9209ce7ce" alt="notion image"
当我们修改之后,在侧边栏至直接提交就是了,简单快捷。也不用任何的设置。
data:image/s3,"s3://crabby-images/ce309/ce309499815b40eec608cb665ced4b41dbe3e40f" alt="notion image"
更多好玩的
我们的项目不仅仅是前端项目,也有可能是后端 Server,这里我就用一个后端 Server来简单演示一下。
安装依赖跑起来
- 全局安装 nodemon
- 进入 server 目录安装依赖
data:image/s3,"s3://crabby-images/94503/94503c6329c9f84411c75a4ddb4def4bc458d6b4" alt="notion image"
很明显报错,因为我们的 server 需要连接 PostgreSQL,而我们没有安装,因此报错。
错误的安装方法
找到一篇教程,照着代码跑起来。
data:image/s3,"s3://crabby-images/fba31/fba314b73f3fddab32794deac56a33446609018e" alt="notion image"
最后,我们会卡在这里,因为我们不知道 codespace 的密码,因此安装失败
docker 出马
我们可以观察到 codespace 已经为我们安装了 docker,而且在现在相当流行容器化部署,上面的那种安装方式也不够优雅。
data:image/s3,"s3://crabby-images/bf78d/bf78d71d59805100e5bcc7c504b788e7cb7f9b36" alt="notion image"
因此运行命令,安装 postgresql
运行之后,找不到镜像会自动去拉取镜像
data:image/s3,"s3://crabby-images/f60c4/f60c4cd7053dc538c3b63493cd56aeb13ded47cf" alt="notion image"
查看下状态
data:image/s3,"s3://crabby-images/2a74e/2a74ed9deaa28f2f7808224acf33ff8029692b6f" alt="notion image"
现在重启 server,发现已经可以连接上了。
data:image/s3,"s3://crabby-images/a20dc/a20dcea2d109072f5c4655baa16ce68294ce134a" alt="notion image"
端口
我们可以在
Forwarded Ports
增加端口转发data:image/s3,"s3://crabby-images/20ec1/20ec124ecf299c27a1e0e0d8a9be3781e2c96337" alt="notion image"
简单演示一下 get 请求,并且是即时的,修改之后可以通过域名来访问。
data:image/s3,"s3://crabby-images/57642/576425f5dd25a005cde34b781c58cdaf50d264bd" alt="notion image"
顺便说一句,如果我们在代码中写好 url 地址,就可以直接用鼠标在命令行打开对应端口,网址也会被进行替换。
data:image/s3,"s3://crabby-images/0b32f/0b32fd4c4250987c01bf1475a55ea874ae86d148" alt="notion image"
注意
但是也需要注意,如果我们用 postman 去请求就无法正常请求结果。
data:image/s3,"s3://crabby-images/77a66/77a6646504b20b10e735d4836b3d8c155050740d" alt="notion image"
如果我们访问
/graphql
,请求就会提示Server cannot be reached
和一些跨域错误。data:image/s3,"s3://crabby-images/5b8e6/5b8e63ad319be786352582dceff71ede94def4f2" alt="notion image"
总结
优点
俗话说,工欲善其事必先利其器。
编程更重要的是一种思想,而编码更重要的是去表达思想。
如果我们将配置环境,机器选择的的步骤省下来,让自己更加专注于思想表达,专注于编码的话,这样会让我们事半功倍。而现在 Github IDE 就可以看成 VSC 的网页版。如果你将 VSC 的配置同步到 Github 账户的话,你打开在线 IDE 的时候就会直接同步配置,你会很快上手。
除此之外,Github 的里面预装各种环境,让你不再苦恼于环境安装,而且所处的网络环境也很棒,各种库、配置下载起来也是很快,我想这对我们的帮助也是很大的。比如再也不用纠结
node-sass
下载不下等尴尬场景。遇到紧急的事情,一个浏览器就可以让你专注开发,这难道不香吗?
不足
虽然 Github 在线 IDE 有很多优点,但是还是有一些不足,肯定不能和 VSC 真机比拟。比如一些接口
/graphql
,就没有本地真机开发的那么爽。除此之外,真机的 VSC 就有很多辅助扩展。比如 PicGo 来实现图片上传到 Github 做图床,在浏览器 IDE 里面经过测试是跑不通的。因为每个人所处的网络环境不同,不用高级姿势访问有可能会出现链接断开的情况,这倒是有点硬伤。🤣
结语
之前听过“阿里 云电脑”,加上现在 5G 的逐渐普及,说不定未来大家需要的只是一个显示器,可以完成学习、工作和娱乐,配置全部都在远端。听起来天方夜谭,说不定在未来就会实现。
一个新兴事物的出来,肯定引起人们的好奇和质疑。仔细想想 Github 被微软收购之后,先后推出了个人无限私有仓库,免费使用 Github Actions,再有 Github Codespaces。而微软也先后推出 TS、VSC 等市场举足轻重的开源项目。我所看到是开源界的发展和繁荣,也希望未来越来越好。
撒花!
- 作者:Kitety
- 链接:https://www.kitety.com/article/github-online-ide-first-experience
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。