assetPrefix
注意: Vercel へのデプロイはあなたの Next.js プロジェクトに対して自動的にグローバル CDN を設定します。 Asset Prefix を手動で設定する必要はありません。
Good to know: Next.js 9.5+は、カスタマイズ可能な基本 Pathをサポートし、これはより良い
/docs
のようなサブ path でアプリケーションをホストするのに適しています。 我々は、このユースケースについて、カスタム Asset Prefix を使用することをお勧めしません。
CDN を設定するには、アセットプレフィックスを設定し、CDN のオリジンを、Next.js がホストされているドメインに解決するように設定できます。
next.config.js
を開き、assetPrefix
の config を追加します:
const isProd = process.env.NODE_ENV === 'production'
module.exports = {
// Use the CDN in production and localhost for development.
assetPrefix: isProd ? 'https://cdn.mydomain.com' : undefined,
}
Next.js は、/_next/
path からロードされる JavaScript および CSS ファイルに対して自動的にアセットプレフィックスを使用します(.next/static/
フォルダ)。例えば、上記の設定で、JS チャンクに対する次の request:
/_next/static/chunks/4b9b41aaa062cbbfeff4add70f256968c51ece5d.4d708494b3aed70c04f0.js
代わりになる:
https://cdn.mydomain.com/_next/static/chunks/4b9b41aaa062cbbfeff4add70f256968c51ece5d.4d708494b3aed70c04f0.js
指定された CDN にファイルをアップロードするための正確な設定は、選択した CDN に依存します。CDN 上でホストする必要があるのは、.next/static/
の内容だけで、それは上記の URL request が示すように_next/static/
としてアップロードされるべきです。あなたの.next/
フォルダの残りをアップロードしないでください、あなたの server コードやその他の設定を公開すべきではありません。
assetPrefix
は_next/static
への Request をカバーしていますが、次の paths には影響を与えません:
- publicフォルダーのファイル。それらのアセットを CDN 経由で提供したい場合、自分でプレフィックスを導入する必要があります。