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の値を変更するだけで簡単にポートを切り替えられます。
環境ごとに適したポートで動作させたい場合に有効です。
著書
article2025年12月21日TypeScriptでミドルウェアを設計する ExpressとNestJSの応用例で型安全に整理する
articleNestJS デプロイ戦略:Blue-Green/Canary と DB マイグレーションの連携
articleNestJS 認可設計:RBAC/ABAC/ポリシーベース(CASL/oso)の実装指針
articleNestJS Guard/Interceptor/Filter 早見表:適用順序とユースケース対応表
articleNestJS Monorepo 構築:Nx/Yarn Workspaces で API・Lib を一元管理
articleNestJS × TypeORM vs Prisma vs Drizzle:DX・性能・移行性の総合ベンチ
article2026年1月4日TypeScriptでi18nを設計する マルチリンガル対応を型安全に運用する戦略
article2026年1月4日TypeScriptでWebSocket双方向通信を作るユースケース 型安全なイベント設計と実装
article2026年1月3日TypeScriptとVitestでテストを運用する 導入から高速化まで活用手順
article2026年1月2日TypeScriptの型情報でドキュメントを自動生成する使い方 陳腐化を防ぐ運用も整理
article2026年1月2日NuxtとTypeScriptで型安全な開発をセットアップする手順 スタートガイド
article2026年1月2日TypeScriptで認証と認可をセキュアに設計する 使い方と実装手順を整理
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 時代へ!『サピエンス全史 下巻』ユヴァル・ノア・ハラリが予見する人類の未来
