Docker を使用した Visual Studio 開発のトラブルシューティング

適用対象:yesVisual Studio noVisual Studio for Mac noVisual Studio Code

Visual Studio コンテナー ツールを使用する際、アプリケーションのビルドまたはデバッグしている間に問題が発生する可能性があります。 一般的なトラブルシューティング手順のいくつかを以下に示します。

ボリューム共有が有効にならない。 Docker CE for Windows の設定でのボリューム共有を有効にする (Linux コンテナーのみ)

ファイル共有を管理する必要があるのは、Docker で Hyper-V を使用している場合だけです。 WSL 2 を使用している場合、次の手順は必要ありません。また、[ファイル共有] オプションは表示されません。 この問題を解決するには、次の操作を行います。

  1. 通知領域で [Windows 用の Docker] を右クリックし、 [設定] を選択します。

  2. [リソース]>[ファイル共有] を選択し、アクセスする必要があるフォルダーを共有します。 システム ドライブ全体を共有することは可能ですが、お勧めできません。

    共有ドライブ

ヒント

Visual Studio では、共有ドライブが構成されていない場合にプロンプトが表示されます。

デバッグを開始できない

理由の 1 つとして、ユーザー プロファイル フォルダーに古いデバッグ コンポーネントが残っていることが考えられます。 次のコマンドを実行してこれらのフォルダーを削除し、次回のデバッグ セッションで最新のデバッグ コンポーネントがダウンロードされるようにしてください。

  • del %userprofile%\vsdbg
  • del %userprofile%\onecoremsvsmon

アプリケーションのデバッグ時のネットワークに固有のエラー

コンテナー ホスト ネットワークのクリーンアップに関するページでダウンロードできるスクリプトを実行してみてください。このスクリプトにより、ホスト コンピューター上のネットワーク関連のコンポーネントが更新されます。

マウントが拒否される

MacOS 用の Docker を使用している場合、フォルダー /usr/local/share/dotnet/sdk/NuGetFallbackFolder を参照するとエラーが発生する可能性があります。 Docker で [File Sharing](ファイル共有) タブにフォルダーを追加します。

Docker users グループ

コンテナーを使用するときに、Visual Studio で次のエラーが発生する場合があります。

The current user must be in the 'docker-users' group to use Docker Desktop. 
Add yourself to the 'docker-users' group and then log out of Windows.

Docker コンテナーを使用する許可を得るには、'docker-users' グループのメンバーである必要があります。 Windows 10 以降で自分自身をグループに追加するには、次の手順を行います。

  1. スタート メニューから、 [コンピューターの管理] を開きます。
  2. [ローカル ユーザーとグループ] を展開し、 [グループ] を選択します。
  3. docker-users グループを検索し、 [グループに追加] を右クリックして選択します。
  4. お使いのユーザー アカウントまたはアカウントを追加します。
  5. いったんサインアウトしてからもう一度サインインして、変更した内容を有効にします。

また、管理者の net localgroup コマンド プロンプトでコマンドを使用して、ユーザーを特定のグループに追加することもできます。

net localgroup docker-users DOMAIN\username /add

PowerShell では、Add-LocalGroupMember 関数を使用します。

ディスク領域不足

Docker では既定でイメージが %ProgramData%/Docker/ フォルダーに格納されます。これは通常、システム ドライブ上にあり、*C:\ProgramData\Docker* となります。 システム ドライブの大切な領域をイメージで占有してしまわないよう、イメージ フォルダーの場所を変更できます。 そのためには次を行います。

  1. タスク バーの Docker アイコンを右クリックし、 [設定] を選択します。
  2. [Docker エンジン] を選択します。
  3. 編集ウィンドウで graph プロパティ設定を追加し、Docker イメージに任意の場所を指定します。
    "graph": "D:\\mypath\\images"

Docker ファイル共有のスクリーンショット

[Apply & Restart] (適用して再起動) をクリックします。 以上の手順で %ProgramData%\docker\config\daemon.json にある設定ファイルが変更されます。 以前に作成したイメージが移動されることはありません。

コンテナーの種類の不一致

プロジェクトに Docker サポートを追加する場合は、Windows または Linux のいずれかのコンテナーを選択します。 Docker サーバー ホストがプロジェクト ターゲットと同じコンテナーの種類を実行するように構成されていない場合は、次のようなエラーが表示されます。

Docker ホストとプロジェクトの不一致のスクリーンショット

この問題を解決するには、システム トレイの Docker for Windows アイコンを右クリックし、[Switch to Windows containers...](Windows コンテナーに切り替える...) または [Switch to Linux containers...](Linux コンテナーに切り替える...) を選択します。

その他の問題

その他の問題が発生した場合は、Microsoft/DockerTools の issue を参照してください。

関連項目