Heroku + Node.js アプリの環境変数の管理に heroku-config と dotenv を使う

Heroku 上に Node.js 製のアプリを載せている時、ローカルと Heroku 上とで、どのように環境変数を管理すると良いか調べた。

目次

Heroku の環境変数管理は heroku-config プラグインを使う

Heroku の環境変数 (Config Vars) の管理には、heroku-config というプラグインを使うのが一番やりやすい。

プラグインは以下のようにインストールする。

$ heroku plugins:install heroku-config

そして、環境変数情報を .env というファイルに書いておく。例として以下のように記述できる。

# PostgreSQL の接続先文字列
DATABASE_URL=postgres://hogehoge:[email protected]:5432/useruser

# PostgreSQL への SSL 接続設定
PGSSLMODE=allow

シャープ # 始まりの行はコメントになるので、分かりやすく書いておける。

当然ながら、この .env ファイルはバージョン管理などに含めないこと。

記述した .env ファイルを Heroku アプリ上で使用したければ、

$ heroku config:push

で Heroku に送ることができ、逆に Heroku 上で設定されている環境変数をダウンロードするには、

$ heroku config:pull

で取得できる。

Node.js コード内で .env ファイルの環境変数を参照するには dotenv パッケージを使う

さて、Node.js スクリプト内で環境変数を参照するには、process.env.DATABASE_URL のように記述するワケだが、.env ファイルで管理している環境変数は勝手には読み込んでくれない。

そこで、dotenv というパッケージを利用し、.env というファイルがあればそのファイルの内容を環境変数として定義させるように、Node.js スクリプトを書き直してみる。

$ npm install --save dotenv

例えば pg パッケージで PostgreSQL に接続するコードで、これまでどおり本当の環境変数しか見ない場合は、以下のように書いていた。

const pg = require('pg');

// 接続先 URL
const connectionString = process.env.DATABASE_URL; // || 'postgres://postgres:postgres@localhost:5432/my_local_db';

// 接続開始
const pool = new pg.Pool({
  connectionString: connectionString
});

ローカル開発環境で、もし process.env.DATABASE_URL を設定したくなった場合は、ターミナル内に環境変数を export したりしていたワケだ。

# このように叩けば process.env.DATABASE_URL の値が設定できる
$ export DATABASE_URL=postgres://hoge:fuga@localhost:5432/another_db
$ node main.js

…が、毎度このように打つのは面倒だし、.env ファイルで管理している環境変数を直接参照できたら便利だよね、というのがこの dotenv の役割だ。

dotenv を使うには、先程のスクリプトの冒頭に、次のようなコードを追加する。

const pg = require('pg');

// 設定をロードする
require('dotenv').config();

// 接続先 URL (以降は同じ)
const connectionString = process.env.DATABASE_URL; // || 'postgres://postgres:postgres@localhost:5432/my_local_db';

あとは特に export コマンドなどは不要で、いきなり $ node main.js と呼び出してやれば、.env ファイルに書かれた環境変数情報を利用できる。

以上

.env というファイルに環境変数を逃がし、本番 (Heroku) 環境とローカル開発環境とで環境変数を容易に切り替えられるようになった。