質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
Vercel

Vercelとは、フロントエンド開発向けのフレームワークです。静的サイトとサーバレス機能のためのクラウドプラットフォームで、簡単にWebサイトやWebサービスをデプロイできます。自動でスケールでき、監視や各種設定も必要ありません。

Q&A

解決済

1回答

267閲覧

Vercelのデータベースが遅すぎる理由は何でしょうか

takahashi-one

総合スコア120

Vercel

Vercelとは、フロントエンド開発向けのフレームワークです。静的サイトとサーバレス機能のためのクラウドプラットフォームで、簡単にWebサイトやWebサービスをデプロイできます。自動でスケールでき、監視や各種設定も必要ありません。

0グッド

1クリップ

投稿2024/08/28 13:46

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へのアクセスでこんなに遅い理由が上記なのか疑問です。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

vercelのリージョンを変更しただけではそのリージョンは反映されないそうで再ビルドが必要らしいです。現在のリージョンの確認方法はプロジェクトのLogsに表示しているログをどれでもいいのでクリックすると右にいろいろな情報が表示されてその中にあるLocationというのがリージョンです。リージョンを変更しただけだとここがWashington, D.Cになっています。再ビルドしてアプリを実行したログのLocationは設定したリージョンになります。スビードテストのファイルをデプロイした後にvercelの設定をいじって遅いなぁとやっていたわけです。設定した後にデプロイするということでした。結果速くなりました。

投稿2024/09/21 05:13

takahashi-one

総合スコア120

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問