| title | Vercel |
|---|
To deploy to Vercel, use adapter-vercel.
This adapter will be installed by default when you use adapter-auto, but adding it to your project allows you to specify Vercel-specific options.
Install with npm i -D @sveltejs/adapter-vercel, then add the adapter to your svelte.config.js:
// @errors: 2307 2345
/// file: svelte.config.js
import adapter from '@sveltejs/adapter-vercel';
export default {
kit: {
adapter: adapter({
// see the section on deployment configuration below
runtime: 'nodejs18.x',
regions: ['iad1'], // if runtime is `edge`, this defaults to `all`
memory: 1024,
maxDuration: undefined, // 5s for Hobby plans, 15s for Pro, 30s for Enterprise
split: false,
external: []
})
}
};To control how your routes are deployed to Vercel as functions, you can specify deployment configuration, either through the defaultConfig option shown above or with export const config inside +server.js, +page(.server).js and +layout(.server).js files.
For example you could deploy some parts of your app as Edge Functions...
/// file: about/+page.js
/** @type {import('@sveltejs/adapter-vercel').Config} */
export const config = {
runtime: 'edge'
};...and others as Serverless Functions (note that by specifying config inside a layout, it applies to all child pages):
/// file: admin/+layout.js
/** @type {import('@sveltejs/adapter-vercel').Config} */
export const config = {
runtime: 'nodejs18.x'
};The following options apply to all functions:
runtime:'edge','nodejs16.x'or'nodejs18.x'(the default)regions: an array of edge network regions (defaulting to["iad1"]for serverless functions) or'all'ifruntimeisedge(its default)split: iftrue, causes a route to be deployed as an individual function. Ifsplitis set totrueat the adapter level, all routes will be deployed as individual functions
Additionally, the following options apply to edge functions:
envVarsInUse: an array of environment variables that should be accessible inside the edge functionexternal: an array of dependencies that esbuild should treat as external when bundling functions. This should only be used to exclude optional dependencies that will not run outside Node
And the following option apply to serverless functions:
memory: the amount of memory available to the function. Defaults to1024Mb, and can be increased up to3008on Pro or Enterprise accountsmaxDuration: maximum execution duration of the function. Defaults to5seconds for Hobby accounts,15for Pro and30for Enterprise
If your functions need to access data in a specific region, it's recommended that they be deployed in the same region (or close to it) for optimal performance.
Vercel makes a set of deployment-specific environment variables available. Like other environment variables, these are accessible from $env/static/private and $env/dynamic/private (sometimes — more on that later), and inaccessible from their public counterparts. To access one of these variables from the client:
// @errors: 2305
/// file: +layout.server.js
import { VERCEL_COMMIT_REF } from '$env/static/private';
/** @type {import('./$types').LayoutServerLoad} */
export function load() {
return {
deploymentGitBranch: VERCEL_COMMIT_REF
};
}/// file: +layout.svelte
<script>
/** @type {import('./$types').LayoutServerData} */
export let data;
</script>
<p>This staging environment was deployed from {data.deploymentGitBranch}.</p>Since all of these variables are unchanged between build time and run time when building on Vercel, we recommend using $env/static/private — which will statically replace the variables, enabling optimisations like dead code elimination — rather than $env/dynamic/private. If you're deploying with edge: true you must use $env/static/private, as $env/dynamic/private and $env/dynamic/public are not currently populated in edge functions on Vercel.
If you have Vercel functions contained in the api directory at the project's root, any requests for /api/* will not be handled by SvelteKit. You should implement these as API routes in your SvelteKit app instead, unless you need to use a non-JavaScript language in which case you will need to ensure that you don't have any /api/* routes in your SvelteKit app.
Projects created before a certain date will default to using Node 14, while SvelteKit requires Node 16 or later. You can change the Node version in your project settings.
You can't access the file system through methods like fs.readFileSync in Serverless/Edge environments. If you need to access files that way, do that during building the app through prerendering. If you have a blog for example and don't want to manage your content through a CMS, then you need to prerender the content (or prerender the endpoint from which you get it) and redeploy your blog everytime you add new content.