WebStorm 2025.3 ヘルプ

Node.js と Docker

Docker を使用すると、Node.js アプリケーションをすばやくブートストラップして、WebStorm から実行、デバッグ、プロファイリングできます。IDE は、新しい Dockerfile を自動的に作成し、イメージをビルドして実行し、ソースコードを同期し、コンテナーに npm 依存関係をインストールすることにより、初期構成を処理します。

WebStorm と Docker のクイックツアー(英語)でいくつかの例を見つけることができます。

始める前に

  1. 設定 | プラグインページのインストール済みタブで、JavaScript DebuggerNode.jsNode.js リモートインタープリターDocker の必須プラグインが有効になっていることを確認します。詳細については、プラグインのマッピングを参照してください。

  2. Docker の説明に従って、Docker をダウンロード、インストール、設定します。

Docker で Node.js ランタイムを構成する

Docker の Node.js ランタイムは、Node.js リモートインタープリターの構成ダイアログで設定します。このダイアログは、設定ダイアログの JavaScript ランタイムページから、または Docker でアプリケーションを実行またはデバッグするために Node.js の実行 / デバッグ構成を作成または編集するを実行する際に開くことができます。

推奨される方法は、設定ダイアログでリモート Node.js ランタイムを設定することです。この場合、ランタイムと関連するパッケージマネージャーをプロジェクトのデフォルトとして設定できます。これにより、Docker で設定された Node.js ランタイムを使用してアプリを実行およびデバッグできるだけでなく、プロジェクトの依存関係の管理、テストの実行、コードの lint チェックも可能になります。以下の npm、pnpm、yarn と DockerアプリケーションをテストするDocker を使用した ESLint を参照してください。

Node.js 実行 / デバッグ構成で直接構成したリモート Node.js ランタイムは、この実行 / デバッグ構成でのみ使用できます。

リモート Node.js ランタイムを作成する

  1. 設定ダイアログ(Ctrl+Alt+S)を開き、言語 & フレームワーク | JavaScript ランタイムに移動します。

  2. ノードランタイムフィールドの横にある the Browse button をクリックします。

    Add runtime - Browse button
  3. 現在構成されているすべてのランタイムのリストが表示されている Node.js ランタイムダイアログで、ツールバーの the Add button をクリックし、コンテキストメニューからリモートの追加を選択します。

    Configure Node.js runtime in Docker container: Add Remote
  4. 開いた Node.js リモートランタイムを構成するダイアログで、Docker を選択します。

  5. サーバーリストから、使用する Docker 構成を選択します。

    Configure Node.js runtime in a Docker container: select Docker server

    または、フィールドの横にある新規をクリックし、Docker サポートを有効にする説明に従って Docker サーバーを構成します。

  6. イメージ名: リストから、使用するイメージを選択します。

    Configure Node.js runtime in a Docker container: select Docker image

    Node.js 実行可能ファイルは自動的に検出され、Node.js インタープリターのパスフィールドに表示されます。

  7. OK をクリックすると、新しいランタイムがリストに追加される Node.js インタープリターダイアログに戻ります。

    Remote runtimes dialog: the new Node.js runtime in Docker added to the list
  8. 新しく構成されたランタイムをプロジェクトのデフォルトとして設定するには、リストでそれを選択し、OK をクリックして JavaScript ランタイムダイアログに戻ります。

    Settings: newly configured remote Node.js runtime selected as default

    WebStorm は、たとえば実行 / デバッグ構成を作成するときに、ノードランタイムリストから Project エイリアスを選択するたびに、このインタープリターを自動的に使用します。

    新しいランタイムに関連付けられたパッケージマネージャーをプロジェクトの依存関係の管理に使用するには、このパッケージマネージャーをプロジェクトのデフォルトとして設定します。そのためには、パッケージマネージャーフィールドにパッケージマネージャーの場所を指定します。詳しくはデフォルトのプロジェクト Node.js ランタイムとパッケージマネージャーを指定するを参照してください。

デフォルトのプロジェクト Node.js ランタイムとパッケージマネージャーを指定する

WebStorm は、実行 / デバッグ構成の作成時など、ノードランタイムリストから Project エイリアスを選択するたびに、デフォルトのプロジェクトインタープリターを自動的に使用します。

デフォルトのプロジェクトパッケージマネージャーは、依存関係を管理するために自動的に使用されます。たとえば、package.json ファイルから <package manager> install を実行したり、ESLint、Prettier などのサードパーティツールをインストールしたりします。

  1. 設定ダイアログ(Ctrl+Alt+S)を開き、言語 & フレームワーク | JavaScript ランタイムに移動します。

  2. ノードランタイムリストから、現在のプロジェクトでデフォルトで使用する構成を選択します。

  3. パッケージマネージャーリストから、使用するパッケージマネージャーに関連付けられているエイリアスを選択します。WebStorm はその位置を自動的に検出します。

    Settings: newly configured remote Node.js runtime selected as default

    または、必要なパッケージマネージャーの場所を手動で指定します。

    • npm 実行可能ファイルのデフォルトの場所は /usr/local/lib/node_modules/npm です。

    • pnpm のデフォルトの場所は、インストール方法によって異なります。

      1. npm を介してインストールするための /usr/local/lib/node_modules/pnpm

      2. カールを介してインストールするための /usr/local/pnpm-global/<version>/node_modules/pnpmcurl -f https://get.pnpm.io/<version>.js | node - add --global pnpm)。

      詳細については、pnpm 公式 Web サイト(英語)を参照してください。

    • ヤーンのデフォルトの場所は /opt/yarn-<version>5 で、たとえば /opt/yarn-v1.22.5 です。

    Configure Node.js runtime in Docker container: set as default project interpreter

npm、pnpm、yarn と Docker

WebStorm を使用すると、ローカルプロジェクトの場合と同じように、プロジェクトの依存関係を管理し、Docker コンテナーでスクリプトを実行できます。

  1. Docker のリモート Node.js ランタイムが構成されていることを確認してください。

  2. デフォルトのプロジェクト Node.js ランタイムとパッケージマネージャーを指定する

  3. プロジェクトの依存関係を管理します。

    • package.json ファイルを開き、ローカル開発と同様に続行します。たとえば、コンテキストメニューから実行 '<package manager> install' を選択します。依存関係は、Docker コンテナー内のデフォルトのパッケージマネージャーを使用してインストールされ、node_modules フォルダーがプロジェクトに表示されます。

    • または、組み込みターミナルAlt+F12)を開き、必要なパッケージを手動でインストールします。たとえば、npm install --save-dev eslint を実行します。

    パッケージのインストールと更新package.json を編集する詳細を参照してください。

  4. スクリプトの実行とデバッグ

Node.js 実行構成を作成する

  1. 実行 | 実行構成の編集に進みます。開いた構成の編集ダイアログで、ツールバーの the Add New Configuration button をクリックし、コンテキストメニューから Node.js を選択します。「実行 / デバッグ構成: Node.js」ダイアログが開きます。

  2. ファイルフィールドで、それを開始するアプリケーションのメインファイルへのパスを指定します(たとえば、Express(英語) アプリケーションの場合は bin/www)。

    Node.js run/debug configuration: JavaScript file specified
  3. 必要に応じて、Node.js アプリケーションの実行とデバッグで説明されているいくつかのオプション設定を指定します。

  4. ノードランタイムリストから、Docker 環境内の関連するリモート Node.js ランタイムを選択します。

    Node.js with Docker: run/debug configuration, select interpreter

    または、ノードランタイムフィールドの横にある the Browse button をクリックし、上記のようにリモート Node.js ランタイムを構成します。

    Node.js with Docker: run/debug configuration, configure runtime, select Add Remote
  5. 自動生成された Docker コンテナーの設定を確認します。the Expand icon をクリックすると、ポップアップで設定が開きます。

    Node.js with Docker: run/debug configuration, Docker container settings
  6. オプション : 下記の説明に従ってポートバインディングを構成します。

ポートバインディングを構成する (オプション)

基本的に、アプリケーションが実行されているポートをコンテナーのポートにバインドする必要があります。

Docker コンテナー設定の編集フィールドの横にある the Browse icon をクリックして、表示される Docker コンテナー設定の編集ダイアログで設定を指定します。

  1. ポートバインディング領域を展開し、ツールバーの the Add button をクリックします。開いたポートバインディングダイアログで、ポートを次のようにマップします。

  2. オプションを変更をクリックして、指定するオプションを選択します。

    Configure Docker container settings: select the port binding options to specify
    • コンテナーポート」フィールドに、アプリケーションで指定されているポートを入力します。

    • ホストポートフィールドに、コンピューターからアプリケーションにアクセスするための任意のポートを入力します。

    • ホスト IP フィールドに、Docker のホストの IP アドレスを入力します。localhost を使用している場合は、127.0.0.1 と入力します。

      Docker: Port binding specified
    • OK をクリックして、新しいポートバインディングがリストに追加される Docker コンテナー設定の編集ダイアログに戻ります。

    Docker: Port binding added
  3. OK をクリックして、実行 / デバッグ構成: Node.js ダイアログに戻り、ポートバインディングが Docker コンテナーの設定フィールドに表示されます。

    Docker: Port binding added

    アプリケーションを実行する

    Running a Node.js application in a Docker container
    1. 上記のようNode.js 実行 / デバッグ構成を作成します。

    2. ツールバーの実行 / デバッグ構成を選択リストから、新しく作成された Node.js 構成を選択します。

    3. the Run button をクリックして実行 / デバッグ構成を選択リストに移動します。

    アプリケーションの出力を確認する

    アプリケーションが期待どおりに機能することを確認するために、WebStorm 組み込みの HTTP クライアントから HTTP リクエストを実行できます。

    Node.js with Docker: connect to a running app with a HTTP Request
    1. HTTP リクエストファイルを作成します。

    2. 次のリクエストを書いてください。

      GET http://<host IP>:<container port>/

      例:

      GET http://127.0.0.1:3010/
    3. ガターの the Run HTTP Request button をクリックし、http://< を実行 ; ホスト IP>:<コンテナー port>/ の横にある the Run HTTP Request button をクリックします。

      Launch a HTTP Request

      アプリケーションの出力は、実行ツールウィンドウの別のタブに表示されます。

      Application output is shown in the Run tool window

    アプリケーションをデバッグする

    Debugging a Node.js application in a Docker container
    1. 必要に応じて、Node.js コードにブレークポイントを設定します。

    2. 上記の説明に従って Node.js 構成を作成し、ツールバーの実行 / デバッグ構成を選択リストから選択して、リストの横にある the Debug button をクリックします。

    3. Node.js アプリケーションと一緒にローカルでデバッガーを起動する場合に進みます。

    アプリケーションをテストする

    WebStorm を使用すると、ローカルで実行するのと同じ方法で、Mocha(英語) テストと Jest(英語) テストを Docker コンテナー内で実行できます。詳細については、「Mocha および Jest」を参照してください。

    1. Docker 内の関連するリモート Node.js ランタイムがプロジェクトのデフォルトとして設定され、選択されていることを確認してください。また、このリモートランタイムに関連付けられたパッケージマネージャーがプロジェクトのデフォルトとして設定されていることも確認してください。詳細については、Docker で Node.js ランタイムを構成するおよび npm、pnpm、yarn と Docker を参照してください。

    2. package.json を開き、必要なテストフレームワークが devDependencies セクションにリストされていることを確認します。

      { "name": "node-express", "version": "0.0.0", "private": true, "dependencies": { "cookie-parser": "~1.4.4", "debug": "~2.6.9", "express": "~4.16.1", "http-errors": "~1.6.3", "morgan": "~1.9.1", "pug": "^3.0.2" }, "devDependencies": { "chai": "^4.3.4", "concurrently": "^6.3.0", "eslint": "^8.1.0", "http-server": "^14.0.0", "jest": "^27.3.1", "mocha": "^9.1.3", "nyc": "^15.1.0" } }
    3. エディターの任意の場所を右クリックして、コンテキストメニューから実行 '<package manager> install' を選択します。

    4. Mocha オフィシャル Web サイト(英語)または Jest オフィシャル Web サイト(英語)の指示に従ってテストを作成します。

    5. Mocha テストの実行Mocha テストのデバッグJest テストの実行Jest テストのデバッグに従って、エディターから直接単一のテストを実行およびデバッグするか、実行 / デバッグ構成を作成して、テストの一部またはすべてを起動します。

    Docker を使用した ESLint

    WebStorm を使用すると、ローカルで実行するのと同じ方法で、Docker コンテナー内のコードに対して ESLint(英語) を実行できます。詳細については、「JavaScript リンターおよび ESLint」を参照してください。

    1. Docker 内の関連するリモート Node.js ランタイムがプロジェクトのデフォルトとして設定され、選択されていることを確認してください。また、このリモートランタイムに関連付けられたパッケージマネージャーがプロジェクトのデフォルトとして設定されていることも確認してください。詳細については、Docker で Node.js ランタイムを構成するおよび npm、pnpm、yarn と Docker を参照してください。

    2. package.json を開き、ESLint が devDependencies セクションにリストされていることを確認します。

      { "name": "node-express", "version": "0.0.0", "private": true, "dependencies": { "cookie-parser": "~1.4.4", "debug": "~2.6.9", "express": "~4.16.1", "http-errors": "~1.6.3", "morgan": "~1.9.1", "pug": "^3.0.2" }, "devDependencies": { "eslint": "^8.1.0" } }
    3. エディターの任意の場所を右クリックして、コンテキストメニューから実行 '<package manager> install' を選択します。

    4. その後、ESLint はローカルでコードを操作するときと同じように機能します。検出された不一致の説明をエディターまたは問題ツールウィンドウで直接表示し、提案されたクイックフィックスを適用します。詳細については、「JavaScript リンターおよび ESLint」を参照してください。

      ESLint in a Docker container
    2025 年 11 月 06 日

    関連ページ:

    プラグインのインストール

    プラグインは WebStorm のコア機能を拡張します。例: プラグインをインストールして、次の機能を取得します。バージョン管理システム、課題追跡システム、ビルド管理サーバー、その他のツールとの統合。さまざまな言語とフレームワークのコーディング支援サポート。ショートカットのヒント、ライブプレビュー、ファイルウォッチャーなど。新しいプログラミング言語を学ぶのに役立つコーディング演習。デフォルトでは、WebStorm には多数のプラグインがバンドルされています。バンドルされたプラグインを無効にするこ...

    Docker

    Docker は、分離された再現可能な環境で実行可能ファイルをデプロイおよび実行するためのツールです。これは、たとえば、本番環境と同じ環境でコードをテストする場合に役立ちます。WebStorm は Docker 機能を統合し、Docker イメージの作成、Docker コンテナーの実行、Docker Compose アプリケーションの管理、パブリックおよびプライベート Docker レジストリの使用など、IDE から直接実行するための支援を提供します。Docker プラグインを有効にするこの機能は...

    JavaScript ランタイム

    推奨ランタイム:このエリアでは、使用するランタイムを選択します。利用可能なランタイムのセットは、インストールされているプラグインによって異なります。パッケージマネージャー:このフィールドでは、現在のプロジェクトのパッケージマネージャー (npm、Yarn、pnpm、bun) を選択します。WebStorm は、これらのマネージャーへの現在のシステムパスに、、エイリアスを使用します。カスタムインストールを使用するには、選択をクリックし、関連するパッケージマネージャーのインストールフォルダーを選...

    npm、pnpm、Yarn

    WebStorm は、npm、pnpm、Yarn、Yarn 2、Yarn 3、Bun と統合されているため、組み込みのターミナルで、IDE 内から再利用可能なコードのパッケージをインストール、検索、更新、削除できます。WebStorm では、npm、Yarn、pnpm スクリプトを実行およびデバッグすることもできます。WebStorm は、package.json ファイルを解析してスクリプトの定義を認識し、スクリプトをツリービューに表示して、ツリー内のスクリプトと package.json ファイル内...

    実行 / デバッグ構成: Node.js

    作成: 次の Node.js バージョンは、WebStorm 2023.3 以降でサポートされています。Node.js 20 - アクティブな長期サポート (LTS) バージョン、Node.js 21 - 現在のバージョン、サポートされている Node.js バージョンの詳細を参照してください。このページでは、構成固有の項目と、すべての実行 / デバッグ構成に共通のオプションについて説明します。この構成の使用方法の詳細については、「Node.js の実行とデバッグ」を参照してください。このダイアロ...

    Node.js の実行とデバッグ

    WebStorm は、Node.js アプリケーションの実行とデバッグを支援します。WebStorm から起動し、すでに実行中のアプリケーションにアタッチするアプリケーションをデバッグできます。始める前に:設定 | プラグインページのインストール済みタブで、Node.js および JavaScript Debugger に必要なプラグインが有効になっていることを確認します。詳細については、「プラグインのマッピング」を参照してください。Node.js アプリケーションを実行する:WebStorm は...