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 デプロイ戦略: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・性能・移行性の総合ベンチ
articleNestJS メモリリーク診断:Node.js Profiler と Heap Snapshot で原因を掴む
articleNode.js 25.x, 24.x, 22.x, 20.x の脆弱性対応:2025 年 12 月版で修正された 3 件の High Severity 問題の詳細
articleEmotion × Vite の最短構築:開発高速化とソースマップ最適設定
articleLangChain を Serverless へ配備:AWS Lambda/Fly.io/Railway の実装手順
articleYarn PnP 互換性チートシート:loader 設定・patch・packageExtensions の書き方
articleElectron IPC 設計チートシート:チャネル命名・型安全・エラーハンドリング定型
articleDocker セキュアイメージ設計:非 root・最小ベース・Capabilities 削減の実装指針
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 時代へ!『サピエンス全史 下巻』ユヴァル・ノア・ハラリが予見する人類の未来