How to read environment variables from Node.js

The process core module of Node.js provides the env property which hosts all the environment variables that were set at the moment the process was started.

The below code runs app.js and set USER_ID and USER_KEY.

USER_ID=239482 USER_KEY=foobar node app.js

That will pass the user USER_ID as 239482 and the USER_KEY as foobar. This is suitable for testing, however for production, you will probably be configuring some bash scripts to export variables.

Note: process does not need to be imported, it is a global object in Node.js.

Here is an example that accesses the USER_ID and USER_KEY environment variables, which we set in above code.

.(..); // "239482"
.(..); // "foobar"

In the same way you can access any custom environment variable you set.

Node.js 20 introduced experimental support for .env files.

Now, you can use the --env-file flag to specify an environment file when running your Node.js application. Here's an example .env file and how to access its variables using process.env.

# .env file
PORT=3000

In your js file

.(..); // "3000"

Run app.js file with environment variables set in .env file.

node --env-file=.env app.js

This command loads all the environment variables from the .env file, making them available to the application on process.env

Also, you can pass multiple --env-file arguments. Subsequent files override pre-existing variables defined in previous files.

node --env-file=.env --env-file=.development.env app.js

Note: if the same variable is defined in the environment and in the file, the value from the environment takes precedence.

In case you want to optionally read from a .env file, it's possible to avoid throwing an error if the file is missing using the --env-file-if-exists flag.

node --env-file-if-exists=.env app.js

Loading .env files programmatically with process.loadEnvFile(path)

As of Node.js v21.7.0 (and v20.12.0 for Node 20 LTS), Node.js provides a built-in API to load .env files directly from your code: process.loadEnvFile(path).

This method loads variables from a .env file into process.env, similar to how the --env-file flag works — but can be invoked programmatically.

Example

const {  } = ('node:process');

// Loads environment variables from the default .env file
();

.(..);

You can also specify a custom path:

const {  } = ('node:process');
('./config/.env');

Notes

  • Parameters: path can be a string, URL, Buffer, or undefined. Default: './.env'.

  • Version history:

    • Added in: v21.7.0, v20.12.0
    • No longer experimental as of v24.10.0
  • Behavior: Values from .env are merged into process.env. Environment variables already set in the process take precedence. Variables like NODE_OPTIONS inside .env have no effect on Node.js startup behavior.