NestJSで起動するポートを.envから参照して起動する設定
NestJSアプリを.envで定義したポートで起動する方法を解説します。
環境ごとに異なるポートを設定できるため、開発やデプロイ時に便利です。
環境変数の管理を可能にする設定
環境変数を管理するために@nestjs/configを導入します。
以下のコマンドでインストールしてください。
shyarn add @nestjs/config
.envファイルでポートを定義する
プロジェクトのルートディレクトリに.envを作成し、ポート番号を定義します。
例えば、ポートを3000に指定する場合は以下のように記述してください。
envPORT=3000
NestJSの設定モジュールを適用する
NestJSのConfigModuleをAppModuleにインポートし、環境変数を読み込むように設定します。
isGlobal: trueを指定すると、全てのモジュールで環境変数を利用できます。
typescriptimport { Module } from '@nestjs/common';
import { ConfigModule } from '@nestjs/config';
import { AppController } from './app.controller';
import { AppService } from './app.service';
@Module({
imports: [
ConfigModule.forRoot({ isGlobal: true }),
],
controllers: [AppController],
providers: [AppService],
})
export class AppModule {}
アプリケーション起動時にポートを設定する
ConfigServiceを使用し、.envのポート番号を取得してアプリケーションを起動します。
環境変数が未定義の場合は、デフォルト値3000を使用するように設定してください。
typescriptimport { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';
import { ConfigService } from '@nestjs/config';
async function bootstrap() {
const app = await NestFactory.create(AppModule);
const configService = app.get(ConfigService);
const port = configService.get<number>('PORT') || 3000;
await app.listen(port);
console.log(`Application is running on: http://localhost:${port}`);
}
bootstrap();
環境変数を反映してアプリを起動する
以下のコマンドでNestJSアプリケーションを起動してください。
.envに設定したポートでアプリが動作します。
shyarn start
設定手順のまとめ
@nestjs/configをインストールする.envでポート番号を設定するConfigModuleをAppModuleに追加するmain.tsでConfigServiceを利用してポートを取得するnpm run startでアプリを起動する
この設定により、.envの値を変更するだけで簡単にポートを切り替えられます。
環境ごとに適したポートで動作させたい場合に有効です。
articleNestJS 2025 年の全体像:Express・Fastify・Serverless の使い分け早わかり
articleNestJS 監視運用:SLI/SLO とダッシュボード設計(Prometheus/Grafana/Loki)
articleNestJS クリーンアーキテクチャ:UseCase/Domain/Adapter を疎結合に保つ設計術
articleNestJS Decorator 速見表:Controller/Param/Custom Decorator の定型パターン
articleNestJS 最短セットアップ:Fastify + TypeScript + ESLint + Prettier を 10 分で
articleNestJS × ExpressAdapter vs FastifyAdapter:レイテンシ/スループットを実測比較
articleWebRTC が「connecting」のまま進まない:ICE 失敗を 5 分で切り分ける手順
articleWeb Components が “is not a constructor” で落ちる時:定義順序と複数登録の衝突を解決
articleVitest モジュールモック技術の基礎と応用:`vi.mock` / `vi.spyOn` を極める
articleVue.js リアクティビティ内部解剖:Proxy/ref/computed を図で読み解く
articleVite CSS HMR が反映されない時のチェックリスト:PostCSS/Modules/Cache 編
articleTailwind CSS 2025 年ロードマップ総ざらい:新機能・互換性・移行の見取り図
blogiPhone 17シリーズの発表!全モデルiPhone 16から進化したポイントを見やすく整理
blogGoogleストアから訂正案内!Pixel 10ポイント有効期限「1年」表示は誤りだった
blog【2025年8月】Googleストア「ストアポイント」は1年表記はミス?2年ルールとの整合性を検証
blogGoogleストアの注文キャンセルはなぜ起きる?Pixel 10購入前に知るべき注意点
blogPixcel 10シリーズの発表!全モデル Pixcel 9 から進化したポイントを見やすく整理
blogフロントエンドエンジニアの成長戦略:コーチングで最速スキルアップする方法
review今の自分に満足していますか?『持たざる者の逆襲 まだ何者でもない君へ』溝口勇児
reviewついに語られた業界の裏側!『フジテレビの正体』堀江貴文が描くテレビ局の本当の姿
review愛する勇気を持てば人生が変わる!『幸せになる勇気』岸見一郎・古賀史健のアドラー実践編で真の幸福を手に入れる
review週末を変えれば年収も変わる!『世界の一流は「休日」に何をしているのか』越川慎司の一流週末メソッド
review新しい自分に会いに行こう!『自分の変え方』村岡大樹の認知科学コーチングで人生リセット
review科学革命から AI 時代へ!『サピエンス全史 下巻』ユヴァル・ノア・ハラリが予見する人類の未来