1036 字
5 分钟
Web开发免费资源指南
一、 前端部署服务 (Frontend Deployment)
对于现代前端框架(如 React, Vue, Svelte)构建的静态或服务端渲染(SSR)应用,以下平台提供了极致的部署体验和慷慨的免费额度。
-
- 免费额度 (Hobby Plan): Vercel 的 Hobby 套餐非常适合个人项目。它提供每月 100GB 带宽、每月 6,000 次 Serverless Function 执行,以及自动 CI/CD。对于个人博客或作品集网站来说绰绰有余。
-
- 免费额度 (Starter Plan): 提供每月 100GB 带宽、300 分钟构建时间(Build Minutes)。它同样拥有强大的全球 CDN、CI/CD、Serverless Functions,并包含表单处理、身份认证等功能。
-
- 免费额度: 免费版提供了无限的静态站点、无限的请求数和无限的带宽。其全球边缘网络性能顶级,并能与 Workers 无缝集成。是纯静态网站的“天花板”选择。
-
- 免费额度 (个人版): 面向中国大陆访问的绝佳选择。个人版(免费)提供不限量的 CDN 流量和不限量的 DDoS 防护,并有每月 10 万次的边缘函数(Edge Functions)调用额度。
二、 后端与全栈部署 (Backend & Full-Stack Deployment)
需要托管 Docker 容器、后端 API 或更复杂的应用时,以下平台提供了强大的 Serverless 或 PaaS(平台即服务)能力。
-
- 免费额度 (Always Free): 永久免费层级包括每月 200 万次请求、180,000 vCPU-秒 的计算时间和 360,000 GiB-秒 的内存使用。它会根据请求自动缩放至零,没有请求时不产生费用。
-
- 免费额度: 提供每月 5 美元的免费信用额度。您可以用来部署任意服务(如 Node.js, Docker, Postgres 等)。对于小型服务,5 美元的额度足以支撑多个项目免费运行。
-
- 免费额度: 使用大于180天的Github账号注册,提供每月 5 美元的免费额度。可以用来部署任意Docker服务(如 Node.js, Docker, Postgres 等)。按照CPU核数、Ram、Storage和实例数量付费。
-
-
免费额度 (Web Services): 提供每月共 750 小时的免费实例运行时间(所有免费 Web 服务共享)。服务在闲置 15 分钟后会自动休眠(下次访问时唤醒)。此外还包括 100GB 免费出口带宽。
-
(请注意:Render 的免费 Postgres 数据库有 30 天的试用期限制,之后会过期,不适合用于永久免费存储。)
-
三、 Serverless Postgres 数据库
Serverless 数据库按需使用、自动扩展,并提供慷慨的永久免费层级。
-
- 免费额度 (Free Tier): 提供 20 个项目,每个项目 0.5 GB 存储空间,每月每个项目 100 计算小时(Compute Hours)。支持数据库分支(Branching)功能,并会在不活动时自动休眠。
-
- 免费额度 (Free Plan): 不只是数据库,更是一个开源的 Firebase 替代品。免费版包含 2 个免费项目、每个项目 500MB 数据库空间、1GB 文件存储、50,000 月活跃用户(Auth),以及实时数据库和边缘函数。
-
- 免费额度:
- 100,000 operations included
- 500 MB storage
- 5 databases
- No credit card required
- 免费额度:
四、 Serverless Redis 缓存
- Upstash
- 免费额度 (Free Tier): 提供了性能极高的 Serverless Redis。免费版支持每天 10,000 条命令,最大 256MB 数据存储,延迟极低,非常适合用作缓存、会话存储或速率限制。
五、 对象存储 (Object Storage)
-
- 免费额度: R2 最大的亮点是 $0 出口(Egress)费用。免费版每月提供 10GB 存储、100 万次 A 类(写入)操作和 1000 万次 B 类(读取)操作。是公共静态资源(如图床)的完美选择。
-
- 免费额度 (标准存储): 为实名认证用户提供每月 10GB 标准存储空间、10GB CDN 回源流出流量、100 万次 GET 请求和 10 万次 PUT/DELETE 请求。适合需要国内访问速度的场景。
-
- 免费额度: B2 以其低廉的价格著称。免费版提供 10GB 存储空间、每天 1GB 的下载流量(通过 Cloudflare CDN 可免费)以及无限的上传。