nextjsで作成したアプリをvercelにデプロイしました。
vercelのDBを使用したらそれが非常に遅いです。
Claudeに聞いてスピードテストのコードを作成してもらいvercelに配置しました。
typescript
1import { db } from '@/lib/db'; 2import { NextResponse } from 'next/server'; 3 4export async function GET() { 5 console.time('Total API Route'); 6 7 console.time('DB Connection'); 8 await db.$connect(); 9 console.timeEnd('DB Connection'); 10 11 console.time('DB Query'); 12 const data = await db.salary.findFirst(); 13 console.timeEnd('DB Query'); 14 15 console.time('DB Disconnect'); 16 await db.$disconnect(); 17 console.timeEnd('DB Disconnect'); 18 19 console.timeEnd('Total API Route'); 20 21 return NextResponse.json(data); 22} 23 24src/lib/db.ts 25import { PrismaClient } from "@prisma/client"; 26declare global { 27 var prisma: PrismaClient | undefined; 28} 29export const db = globalThis.prisma || new PrismaClient(); 30if (process.env.NODE_ENV !== "production") globalThis.prisma = db;
下記が結果です
DB Connection: 1.339s
21:35:10.480DB Query: 1.084s
21:35:10.481DB Disconnect: 6.67ms
21:35:10.481Total API Route: 2.432s
再びClaudeに聞いたら下記のような回答ですた。
DB Connection: 1.339s
データベースへの接続に1.3秒以上かかっています。これは非常に長い時間です。
DB Query: 1.084s
クエリの実行に約1秒かかっています。単純なクエリ(例:findFirst())であれば、これも長すぎると言えます。
DB Disconnect: 6.67ms
切断時間は問題ありません。
Total API Route: 2.432s
全体で2.4秒かかっています。ウェブアプリケーションとしては遅いと言えます。
Serverless FunctionのリージョンはTokyoで
DBのリージョンはシンガポールです。
DBのデータはお試しなので17列1行のデータしかありません。何百何千のデータでなくたった1つです。
vercelは無料プランです
ClaudeとChat Gptのアドバイス
リージョンを合わせる (DBのリージョンにtokyoがないため両方シンガポールにしたが変わらず)
コールドスタート
データベース接続のオーバーヘッド
接続プーリングの導入
キャッシュの利用
しかしこのような単純なクエリの実行でしかもデータが1つしかないDBへのアクセスでこんなに遅い理由が上記なのか疑問です。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。