为了投入AI的怀抱,将Nextjs项目从Vercel迁移到了CF,结果是好的,过程是痛苦的

天下苦Vercel久矣

这应该是每个使用Nextjs开发一直想说的话,我在这里帮大家喊出来 🎺。

很多人使用Nextjs都直接部署到Vercel上,方便又快捷,一键部署爽歪歪,不过说实话,没有特别的要求它是真的舒服。

但是!!!

如果你想要做AI项目而且是白嫖党,vercel是有限制的,接口默认10s,最高60s的返回,一些久一点的接口,就直接废了,升级高达20美金,这是钱的问题吗?这是命!!!

最近在研究一些AI集成,就被这个问题卡住了,最后发现了赛博菩萨CloudFlare的存在,决定将项目部署到CF上。

蛋疼的edge runtime

因为项目的技术栈是supabase、prisma、nextjs,所以想要迁移到cf上需要对项目进行几个改造。

1.首先是nextjs的改造。

安装对应的cf库

js 复制代码
pnpm add -D @cloudflare/next-on-pages

然后添加一个项目信息文件,2. wrangler.toml

ini 复制代码
name = "filetohtml"
compatibility_date = "2025-03-22"
compatibility_flags = ["nodejs_compat"]
pages_build_output_dir = ".vercel/output/static"

然后在nextjs.config.js添加下面的内容

js 复制代码
import { setupDevPlatform } from "@cloudflare/next-on-pages/next-dev";

if (process.env.NODE_ENV === "development") {
  await setupDevPlatform();
}

\\ ...你原本的内容

2.prisma和supabase的结合使用问题,因为prisma链接postresql时使用了pg相关的库,在edge runtime时是无法使用的,所以需要将其改为所有数据库调用都使用supabase.js。

这也是一个大工程,supabase是支持edge运行的,那么我们要用supabase作为数据库调用工具,不能使用prisma orm了。

js 复制代码
import { createClient } from "@supabase/supabase-js";  
  
export function getSupabaseClient() {  
  const client = createClient(  
    process.env.SUPABASE_URL || "",  
    process.env.SUPABASE_ANON_KEY || ""  
  );  
  
  return client;  
}

3.nextjs的问题,根据文档来弄,需要将所有的route和page添加代码。

js 复制代码
export const runtime = "edge";

指定在edge上运行。

4.添加命令行

js 复制代码
"pages:build": "pnpm dlx @cloudflare/next-on-pages@1",
"preview": "pnpm pages:build && wrangler pages dev",
"deploy": "pnpm pages:build && wrangler pages deploy"

因为我的项目是用pnpm下包的,所以也要使用pnpm部署,这个要切记,用cf默认的部署命令是npm,有可能会出现部署问题。

部署设置按照图来设置。

舒服的cf

部署到cf之后,调用ai接口就没有限制问题了。

cf还有很多免费的功能,dns、安全、d1数据库等等一大堆功能,满足大部分的需求。

最后

附上这周集成ai功能做的一个小项目---文件生成html

相关推荐
hhzz10 分钟前
Pythoner 的Flask项目实践-在web页面实现矢量数据转换工具集功能(附源码)
前端·python·flask
lypzcgf10 分钟前
Coze源码分析-资源库-编辑工作流-前端源码-核心流程/API/总结
前端·工作流·coze·coze源码分析·智能体平台·ai应用平台·agent平台
lypzcgf11 分钟前
Coze源码分析-资源库-编辑工作流-前端源码-核心组件
前端·工作流·coze·coze源码分析·智能体平台·agent平台
有梦想的攻城狮12 分钟前
从0开始学vue:vue和react的比较
前端·vue.js·react.js
FIN666816 分钟前
昂瑞微,凭啥?
前端·科技·产品运营·创业创新·制造·射频工程
kura_tsuki1 小时前
[Web网页] Web 基础
前端
OopsOutOfMemory2 小时前
LangChain源码分析(十三)- 运行时与监控
ai·langchain·aigc·ai编程·ai应用
鱼樱前端2 小时前
uni-app快速入门章法(二)
前端·uni-app
silent_missile2 小时前
vue3父组件和子组件之间传递数据
前端·javascript·vue.js
OopsOutOfMemory3 小时前
LangChain源码分析(一)- LLM大语言模型
人工智能·语言模型·langchain·aigc