Node.js と Docker
Docker を使うと、Node.js アプリケーションを GoLand から素早く実行、デバッグ、プロファイリングできるようにブートストラップできます。 IDE が初期構成を自動的に行い、新しい Dockerfile を作成し、イメージをビルドして実行し、ソースコードを同期し、コンテナー内に npm 依存関係をインストールします。
WebStorm と Docker のクイックツアー(英語)でいくつかの例を見つけることができます。
始める前に
JavaScript と TypeScript、 JavaScript デバッガー、 Docker の必要なプラグインが 設定 | プラグイン ページ、 インストール済み タブで有効化されていることを確認してください。 詳細については、 プラグインの管理を参照してください。
設定 | プラグイン ページ、 マーケットプレース タブで Node.js および Node.js リモートインタープリター プラグインを、 JetBrains Marketplace からプラグインをインストールするの説明に従ってインストールしてください。
設定 | プラグイン ページ、 マーケットプレース タブで Node.js および Node.js リモートインタープリター プラグインを、 JetBrains Marketplace からプラグインをインストールするの説明に従ってインストールしてください。
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 ランタイムを作成する
設定 ダイアログ(Ctrl+Alt+S )を開き、 に進みます。
ノードランタイム フィールドの横にある
をクリックします。

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

開いた Node.js リモートランタイムを構成するダイアログで、 Docker(ドッカー) を選択します。
サーバー リストから、使用する Docker 構成を選択します。

または、フィールドの横にある 新規 をクリックし、 Docker サポートを有効にする説明に従って Docker サーバーを構成します。
イメージ名 リストから、使用するイメージを選択します。

Node.js 実行可能ファイルは自動的に検出され、 Node.js ランタイムパス フィールドに表示されます。
OK をクリックすると、新しいランタイムがリストに追加される Node.js ランタイム ダイアログに戻ります。

新しく構成されたランタイムをプロジェクトのデフォルトとして設定するには、リストでそれを選択し、 OK をクリックして JavaScript ランタイム ダイアログに戻ります。

GoLand は、 ノードランタイム リストから
プロジェクトエイリアスを選択するたびに、自動的にこのインタープリターを使用します。たとえば、実行 / デバッグ構成の作成時などです。新しいランタイムに関連付けられたパッケージマネージャーをプロジェクトの依存関係の管理に使用するには、このパッケージマネージャーをプロジェクトのデフォルトとして設定します。 そのためには、 パッケージマネージャー フィールドにパッケージマネージャーの場所を指定します。 詳細は プロジェクトのデフォルト Node.js ランタイムとパッケージマネージャーの指定 を参照してください。
デフォルトのプロジェクト Node.js ランタイムとパッケージマネージャーを指定する
GoLand は、 ノードランタイム リストから プロジェクト エイリアスを選択するたびに、自動的にデフォルトのプロジェクトインタープリターを使用します。たとえば、実行 / デバッグ構成の作成時などです。
デフォルトのプロジェクトパッケージマネージャーは、依存関係を管理するために自動的に使用されます。たとえば、 package.json ファイルから <package manager> install を実行したり、ESLint、Prettier などのサードパーティ製ツールをインストールしたりします。
設定 ダイアログ(Ctrl+Alt+S )を開き、 に進みます。
ノードランタイム リストから、現在のプロジェクトでデフォルトで使用する構成を選択します。
パッケージマネージャー リストから、使用するパッケージマネージャーに関連付けられているエイリアスを選択します。 GoLand はその場所を自動的に検出します。

または、必要なパッケージマネージャーの場所を手動で指定します。
npm 実行可能ファイルのデフォルトの場所は
/usr/local/lib/node_modules/npmです。pnpm のデフォルトの場所は、インストールメソッドによって異なります:
npm を介してインストールするための /usr/local/lib/node_modules/pnpm 。
カールを介してインストールするための /usr/local/pnpm-global/<version>/node_modules/pnpm (
curl -f https://get.pnpm.io/<version>.js | node - add --global pnpm)。
詳細については、 pnpm 公式 Web サイト(英語)を参照してください。
ヤーンのデフォルトの場所は /opt/yarn-<version>5 で、たとえば /opt/yarn-v1.22.5 です。

npm、pnpm、yarn と Docker
GoLand を使うと、ローカルプロジェクトのように、プロジェクトの依存関係を管理し、Docker コンテナー内でスクリプトを実行できます。
Docker のリモート Node.js ランタイムが構成されていることを確認してください。
プロジェクトの依存関係を管理します。
package.json ファイルを開き、ローカル開発と同様に作業を進めます。たとえば、コンテキストメニューから 実行 '<パッケージマネージャー> install' を選択してください。 依存関係は、Docker コンテナー内のデフォルトパッケージマネージャーでインストールされ、 node_modules フォルダーがプロジェクト内に作成されます。
または、組み込みの ターミナル (Alt+F12 )を開き、必要なパッケージを手動でインストールします。例えば、
npm install --save-dev eslintを実行します。
詳しくは パッケージのインストールと更新 および package.json を編集 をご覧ください。
Node.js 実行構成を作成する
に進みます。 開いた 構成の編集 ダイアログで、ツールバーの
をクリックし、コンテキストメニューから Node.js を選択します。 「実行 / デバッグ構成: Node.js 」ダイアログが開きます。
ファイル フィールドで、それを開始するアプリケーションのメインファイルへのパスを指定します(たとえば、 Express(英語) アプリケーションの場合は bin/www )。

必要に応じて、 Node.js アプリケーションの実行とデバッグで説明されているいくつかのオプション設定を指定します。
ノードランタイム リストから、Docker 環境内の関連するリモート Node.js ランタイムを選択します。

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

自動生成された Docker コンテナーの設定を確認します。
をクリックすると、ポップアップで設定が開きます。

オプション: 下記の説明に従ってポートバインディングを構成します。
ポートバインディングを構成する (オプション)
基本的に、アプリケーションが実行されているポートをコンテナーのポートにバインドする必要があります。
Docker コンテナー設定の編集フィールドの横にある をクリックして、表示される Docker コンテナー設定の編集 ダイアログで設定を指定します。
ポートバインディング 領域を展開し、ツールバーの
をクリックします。 開いた ポートバインディング ダイアログで、ポートを次のようにマップします。
オプションを変更 をクリックして、指定するオプションを選択します。
「コンテナーポート 」フィールドに、アプリケーションで指定されているポートを入力します。
ホストポート フィールドに、コンピューターからアプリケーションにアクセスするための任意のポートを入力します。
OK をクリックして、新しいポートバインディングがリストに追加される Docker コンテナー設定の編集 ダイアログに戻ります。
OK をクリックして、 実行/デバッグ構成: Node.jsダイアログに戻ると、ポートバインディングが Docker コンテナーの設定 フィールドに表示されます。

アプリケーションを実行する
Node.js 実行/デバッグ構成を 上記のとおり 作成します。
ツールバーの 実行 / デバッグ構成を選択 リストから、 新しく作成された Node.js 構成を選択します。
をクリックして 実行 / デバッグ構成を選択 リストに移動します。
アプリケーションの出力を確認する
アプリケーションが期待どおりに動作することを確認するには、GoLand の 組み込み HTTP クライアントから HTTP リクエストを実行できます。
HTTP リクエストファイルを作成します。
次のリクエストを書いてください:
GET http://<host IP>:<container port>/例:
GET http://127.0.0.1:3010/ガターの
をクリックし、 http://<host IP>:<container port>/ を実行します。 の横にある
をクリックします。
アプリケーションの出力は、 実行 ツールウィンドウの別のタブに表示されます。
アプリケーションをデバッグする
アプリケーションをテストする
GoLand を使うと、ローカルと同じように Docker コンテナー内で Mocha および Jest テストを実行できます。 詳細については Mocha および Jest を参照してください。
Docker 内の関連するリモート Node.js ランタイムがプロジェクトのデフォルトとして設定され、選択されていることを確認してください。 また、このリモートランタイムに関連付けられたパッケージマネージャーがプロジェクトのデフォルトとして設定されていることを確認してください。 詳細については、 Docker で Node.js ランタイムを構成する および npm、pnpm、yarn と Docker を参照してください。
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" } }エディターの任意の場所を右クリックして、コンテキストメニューから 実行 '<パッケージマネージャー> install' を選択します。
Mocha オフィシャル Web サイト(英語)または Jest オフィシャル Web サイト(英語)の指示に従ってテストを作成します。
Mocha テストの実行、 Mocha テストのデバッグ、 Jest テストの実行、 Jest テストのデバッグに従って、エディターから直接単一のテストを実行およびデバッグするか、実行 / デバッグ構成を作成して、テストの一部またはすべてを起動します。
Docker を使用した ESLint
GoLand を使うと、ローカルと同じように Docker コンテナー内でコードに対して ESLint を実行できます。 詳細については JavaScript リンター および ESLint を参照してください。
Docker 内の関連するリモート Node.js ランタイムがプロジェクトのデフォルトとして設定され、選択されていることを確認してください。 また、このリモートランタイムに関連付けられたパッケージマネージャーがプロジェクトのデフォルトとして設定されていることを確認してください。 詳細については、 Docker で Node.js ランタイムを構成する および npm、pnpm、yarn と Docker を参照してください。
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" } }エディターの任意の場所を右クリックして、コンテキストメニューから 実行 '<パッケージマネージャー> install' を選択します。
その後、ESLint は、コードをローカルで操作する場合と同じように機能します。 検出された不一致の説明をエディターまたは 問題 ツールウィンドウで表示し、提案されたクイックフィックスを適用します。 詳細については JavaScript リンター および ESLint を参照してください。