5分钟快速上线Web应用和API(Vercel)

LiamH · · 2505 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

> 上周有个童鞋问我如何快速搭建一个Web应用,想拿来练手,就不考虑购置服务器。我推荐了前段时间很火的`Vercel`,接下来我带你5分钟上手! #### Vercel [Vercel](https://vercel.com/) 你可以理解为一个部署工具,支持部署静态网页和Node服务,部署后你还可以访问它自带生成的域名https。 ![vercel官网](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/8224e8399c0e437fb3df7a0e2bffd7c4~tplv-k3u1fbpfcp-watermark.image?) 不仅仅如此,除了他的亲儿子`Nextjs`之外,它还提供了很多模版支持,譬如: - Nuxt.js: Vue的SSR框架 - Hexo: 快速生成博客网站 - Remix: 一款边缘原生的全栈 JavaScript 框架 - 模版多达30种.. ![模版支持](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/efd609bcfd5b46dc9593b21eebb61b49~tplv-k3u1fbpfcp-watermark.image?) Vercel的核心主要包括开发、预览、部署。通过授权Github给Vercel后,就可以选择我们要部署的项目Github仓库,项目就自动更新部署了。接下来教你一步到位! #### 1.选择模版 > 本次演示实践框架,我选用vercel的亲儿子`Next.js`。他提供了很多🌰案例,这里我选择一个 模版:[with-vercel-fetch](https://github.com/vercel/next.js/tree/canary/examples/with-vercel-fetch)。来实现一个简单的SSR服务。 ![选择模版](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/81367d23620b407383b2a8d953c7438a~tplv-k3u1fbpfcp-watermark.image?) 在Vercel创建一个项目,你会发现`Vercel`跟Github是可以联动的!支持帮你创建一个私有的Github仓库,本质是类似Github Page,但是Github Page的访问速度太慢。这点Vercel直接秒杀了。 ![](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/5ac4577d47054365a20c3eb645438c4f~tplv-k3u1fbpfcp-watermark.image?) 在Vercel帮我们创建的仓库之后,对Demo仓库做一些调整 👇 ![](https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/6606d3a465e349f2a616e3e946f372db~tplv-k3u1fbpfcp-watermark.image?) 这里我fetch的API接口使用的是`Apifox`提供的`云端Mock`的功能,自己不用搭建一套后端服务也可以调接口数据!🔥 在Apifox的Web版中新建一个接口,然后对接口返回字段进行Mock自定义(支持自定义Mock数据)👇 这是我自定义的一个云端Mock接口 https://mock.apifox.cn/m1/388694-0-default/star/list ![Apifox 云端Mock](https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/367e3519477447dc814a0c11f9bb8323~tplv-k3u1fbpfcp-watermark.image?) 感兴趣的小伙伴可以体验下 👉 [Apifox](https://www.apifox.cn/?utm_source=liam) #### 2.发布 完成上述步骤后,vercel会自动执行部署环节,并生成访问域名,同时你可以看到应用的预览效果! ![发布成功](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/ef4dc20bd3e14e1e93248606ae7799b6~tplv-k3u1fbpfcp-watermark.image?) 而且后期你的github仓库只`main`分支有任何改动,`vercel`可以自动触发Deploy部署。 最后访问一下我们用vercel部署好的页面 ![](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/b1fd1dd7a061404f9d1a1b01bb6aa4c3~tplv-k3u1fbpfcp-zoom-1.image) > 👨‍🎓 阿乐同学:那如果我想替换域名可以嘛?不用他分配的域名 可以的,如果你想绑定独立域名,你可以操作`view domain` 进行自定义域名绑定,最后去域名解析解决解析`CNAME`到`cName.vercel-dns.com` ![自定义域名](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d2b0d26fede540ea84ba64f9e12f561e~tplv-k3u1fbpfcp-watermark.image?) #### 3.其他部署方式 Vercel提供`deploy Hook`, 你可以在vercel创建的项目中的控制面板上配置deploy hook,只需要填写deploy(部署)的分支 `git branch`, 还有对应的hook名称(自定义),就可以配置一个独立的触发方式。 配置如下 👇 ![image.png](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/0f614cb990024af8844db9e0e75cd7cb~tplv-k3u1fbpfcp-watermark.image?) 最后我们在命令行中发起请求,就可以触发该项目的构建部署了。是不是很方便!🚀 ``` curl -X POST https://api.vercel.com/v1/integrations/deploy/prj_GeziGEUiSxxxxxx/tV4Wm5MO2j ``` #### 4.Serverless 相关 > Vercel 本质上是一个零配置的Serverless部署平台,那什么是Serverless呢? 你可以看看之前树酱写的文章:[📒 你学BFF和Serverless了吗](https://juejin.cn/post/6844904185427673095) ![Serverless](https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/b59cfdff913a45ba9d96dd2880d68ce6~tplv-k3u1fbpfcp-watermark.image?) Vercel实现`Serverless`的底层是基于`AWS`(亚马逊云) 的`lambda`这座大山。我们用`vercel`可以部署`Serverless 接口`,接下来我们通过本地来开发一个简单的 Serverless API 在本地项目中执行 👇 ``` 1. npm install vercel@latest -g (全局安装) 2. vercel login 3. vercel (除了初始化.vercel文件 也可以触发项目的Deploy部署) ``` ![初始化vercel](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cf76fc09f2fd429989965801301ebff0~tplv-k3u1fbpfcp-watermark.image?) 完成上诉操作后,我们就可以开工了!我们发现vercel命令会帮我们创建 `.vercel`文件夹,然后我们在跟目录创建一个api文件夹,并在其中新建一个`"云函数"` message,我们看下代码结构! ![云函数代码](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/4cf23ba20ae04dcc85f9ead1ebf730ad~tplv-k3u1fbpfcp-watermark.image?) 最后重新执行vercel,就可以部署这个`Serverless API`了! 我们再用Apifox调试一下!成功返回! ![Apifox调试](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/8162b7c88fb343ad8792d7cbefec5303~tplv-k3u1fbpfcp-watermark.image?)

有疑问加站长微信联系(非本文作者))

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2505 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传