Environment Variables
Learn to add and access environment variables in your Next.js application.
Examples
Next.js comes with built-in support for environment variables, which allows you to do the following:
- Use
.env
to load environment variables - Bundle environment variables for the browser by prefixing with
NEXT_PUBLIC_
Loading Environment Variables
Next.js has built-in support for loading environment variables from .env*
files into process.env
.
Note: Next.js also supports multiline variables inside of your .env*
files:
Note: If you are using a /src
folder, please note that Next.js will load the .env files only from the parent folder and not from the /src
folder.
This loads process.env.DB_HOST
, process.env.DB_USER
, and process.env.DB_PASS
into the Node.js environment automatically allowing you to use them in Route Handlers.
For example:
Loading Environment Variables with @next/env
If you need to load environment variables outside of the Next.js runtime, such as in a root config file for an ORM or test runner, you can use the @next/env
package.
This package is used internally by Next.js to load environment variables from .env*
files.
To use it, install the package and use the loadEnvConfig
function to load the environment variables:
Then, you can import the configuration where needed. For example:
Referencing Other Variables
Next.js will automatically expand variables that use $
to reference other variables e.g. $VARIABLE
inside of your .env*
files. This allows you to reference other secrets. For example:
In the above example, process.env.TWITTER_URL
would be set to https://x.com/nextjs
.
Good to know: If you need to use variable with a $
in the actual value, it needs to be escaped e.g. \$
.
Bundling Environment Variables for the Browser
Non-NEXT_PUBLIC_
environment variables are only available in the Node.js environment, meaning they aren't accessible to the browser (the client runs in a different environment).
In order to make the value of an environment variable accessible in the browser, Next.js can "inline" a value, at build time, into the js bundle that is delivered to the client, replacing all references to process.env.[variable]
with a hard-coded value. To tell it to do this, you just have to prefix the variable with NEXT_PUBLIC_
. For example:
This will tell Next.js to replace all references to process.env.NEXT_PUBLIC_ANALYTICS_ID
in the Node.js environment with the value from the environment in which you run next build
, allowing you to use it anywhere in your code. It will be inlined into any JavaScript sent to the browser.
Note: After being built, your app will no longer respond to changes to these environment variables. For instance, if you use a Heroku pipeline to promote slugs built in one environment to another environment, or if you build and deploy a single Docker image to multiple environments, all NEXT_PUBLIC_
variables will be frozen with the value evaluated at build time, so these values need to be set appropriately when the project is built. If you need access to runtime environment values, you'll have to setup your own API to provide them to the client (either on demand or during initialization).
Note that dynamic lookups will not be inlined, such as:
Runtime Environment Variables
Next.js can support both build time and runtime environment variables.
By default, environment variables are only available on the server. To expose an environment variable to the browser, it must be prefixed with NEXT_PUBLIC_
. However, these public environment variables will be inlined into the JavaScript bundle during next build
.
You can safely read environment variables on the server during dynamic rendering:
This allows you to use a singular Docker image that can be promoted through multiple environments with different values.
Good to know:
- You can run code on server startup using the
register
function. - We do not recommend using the runtimeConfig option, as this does not work with the standalone output mode. Instead, we recommend incrementally adopting the App Router.
Default Environment Variables
Typically, only .env*
file is needed. However, sometimes you might want to add some defaults for the development
(next dev
) or production
(next start
) environment.
Next.js allows you to set defaults in .env
(all environments), .env.development
(development environment), and .env.production
(production environment).
Good to know: .env
, .env.development
, and .env.production
files should be included in your repository as they define defaults. All .env
files are excluded in .gitignore
by default, allowing you to opt-into committing these values to your repository.
Environment Variables on Vercel
When deploying your Next.js application to Vercel, Environment Variables can be configured in the Project Settings.
All types of Environment Variables should be configured there. Even Environment Variables used in Development – which can be downloaded onto your local device afterwards.
If you've configured Development Environment Variables you can pull them into a .env.local
for usage on your local machine using the following command:
Good to know: When deploying your Next.js application to Vercel, your environment variables in .env*
files will not be made available to Edge Runtime, unless their name are prefixed with NEXT_PUBLIC_
. We strongly recommend managing your environment variables in Project Settings instead, from where all environment variables are available.
Test Environment Variables
Apart from development
and production
environments, there is a 3rd option available: test
. In the same way you can set defaults for development or production environments, you can do the same with a .env.test
file for the testing
environment (though this one is not as common as the previous two). Next.js will not load environment variables from .env.development
or .env.production
in the testing
environment.
This one is useful when running tests with tools like jest
or cypress
where you need to set specific environment vars only for testing purposes. Test default values will be loaded if NODE_ENV
is set to test
, though you usually don't need to do this manually as testing tools will address it for you.
There is a small difference between test
environment, and both development
and production
that you need to bear in mind: .env.local
won't be loaded, as you expect tests to produce the same results for everyone. This way every test execution will use the same env defaults across different executions by ignoring your .env.local
(which is intended to override the default set).
Good to know: similar to Default Environment Variables, .env.test
file should be included in your repository, but .env.test.local
shouldn't, as .env*.local
are intended to be ignored through .gitignore
.
While running unit tests you can make sure to load your environment variables the same way Next.js does by leveraging the loadEnvConfig
function from the @next/env
package.
Environment Variable Load Order
Environment variables are looked up in the following places, in order, stopping once the variable is found.
process.env
.env.$(NODE_ENV).local
.env.local
(Not checked whenNODE_ENV
istest
.).env.$(NODE_ENV)
.env
For example, if NODE_ENV
is development
and you define a variable in both .env.development.local
and .env
, the value in .env.development.local
will be used.
Good to know: The allowed values for NODE_ENV
are production
, development
and test
.
Good to know
- If you are using a
/src
directory,.env.*
files should remain in the root of your project. - If the environment variable
NODE_ENV
is unassigned, Next.js automatically assignsdevelopment
when running thenext dev
command, orproduction
for all other commands.
Version History
Version | Changes |
---|---|
v9.4.0 | Support .env and NEXT_PUBLIC_ introduced. |