LoginSignup
5
5

VSCodeからDockerコンテナへアタッチする手順

Last updated at Posted at 2023-09-01

概要

Dockerコンテナを開発環境として活用する際、VSCodeと連携したい、デバッグしたいというニーズがあります。特にホストPCからssh接続したサーバやPC上に存在するコンテナにアタッチして開発したいという状況はあるのではないでしょうか。
step_00.PNG
ここでは詳細手順を示します。

前提条件

  • VSCodeがホストPCにインストール済である事
  • サーバへアクセスするためのユーザアカウントとパスワードを付与されている事
  • サーバ側でアタッチするコンテナを生成済である事

作業環境

  • ホストPC

    エディション Windows 10
    バージョン 22H2
    
  • サーバ

    Distributor ID: Ubuntu
    Description:    Ubuntu 20.04.5 LTS
    Release:        20.04
    Codename:       focal
    
  • VSCode
    バージョン: 1.81.0

なおアタッチするコンテナは、サーバにて生成・起動しており、コンテナ名は「test_container」とします。

サーバへのssh接続

はじめにサーバとssh接続する必要があります。ただしサーバとの初回接続時には設定が必要になります。ここではエクステンション「Remote-Development」のインストールからssh接続完了までを示します。

  1. VSCodeのエクステンション「Remote-Development」をインストールします。
    ※図は既にインストール済の状態のため、「インストール」ボタンが表示されていません。
    step_00_rd.PNG

  2. Remote-Developmentのインストール完了すると左側にリモートエクスプローラのアイコンが表示されので、リモートエクスプローラのアイコンをクリックした後、図のギア(SSH構成ファイルを開く)アイコンをクリックします。
    step_00_prepro_ssh_00.PNG

  3. ssh構成ファイルの選択を要求されます。
    環境によって若干異なりますが、選択肢は概ね以下の二つです。

    • C:\Users\<ユーザ名>.ssh\config
    • C:\ProgramData\ssh\ssh_config
      どちらを選択しても問題ありません。
      step_00_prepro_ssh_01.PNG
  4. 自動的にssh設定ファイルが開くので、ssh接続の設定を入力します。
    入力項目は以下のようになります。

    No タグ名 入力内容
    1 Host 接続先の名称(わかりやすい名称を任意に設定)
    2 HostName 接続先のIPアドレス
    3 User 接続先にログインする際のユーザ名
    4 Port ssh接続に使用するポート番号(デフォルト:22)

    step_00_prepro_ssh_02.PNG

  5. ssh設定の入力が完了したら保存した後、リモートエクスプローラの更新アイコンをクリックします。
    step_00_prepro_ssh_03.PNG

  6. 先ほど設定した接続先(Hostタグに入力した値)が表示されたら成功です。
    次に接続先の名称を右クリックして、実際の接続処理を行います。今回は「development_env」に接続してみます。このとき「現在のウィンドウでアタッチする」と「新しいウィンドウでアタッチする」が表示されますが、どちらを選んでも構いません。
    step_00_prepro_ssh_04.PNG

  7. 次のような画面に遷移するので、接続先の環境に併せて選択してください。
    今回は接続先サーバのOSがUbuntuですので、「Linux」をクリックします。
    step_00_prepro_ssh_05.PNG

  8. 次にパスワードの入力を求められるので、接続先サーバにログインする際のユーザに紐づくパスワードを入力してください。
    step_00_prepro_ssh_06.PNG

  9. ログインが成功すると次のような画面になります。左下に接続先情報が表示されているので、確認してみてください。
    step_00_prepro_ssh_07.PNG

トラブルシュート

何事もなくssh接続することが出来ればよいのですが、「接続できない!」ということもあるかと思います。全てのケースを網羅する事は出来ませんが、私たちが実施した確認と対策について共有します。ちなみにssh接続に失敗すると以下のようなダイアログが表示されます。
step_00_prepro_ssh_08_troubleshoot.PNG

確認① ssh構成ファイルのパス設定

先程設定したssh構成ファイルですが、上記の作業にて自動的にVSCodeへパス設定されます。
このためssh構成ファイルのパス設定を確認してみます。
確認手順ですが、まず左下のギアアイコンをクリック後、「設定」を選択します。
step_00_prepro_ssh_09_troubleshoot.PNG

表示された設定画面の「設定の検索」に「ssh」と入力します。これにより、ssh接続に関連する設定情報が列挙されます。この中で、「Remote.SSH: Config File」を確認してみます。
step_00_prepro_ssh_10_troubleshoot.PNG

もしssh接続に失敗した際に、ここが空であればssh構成ファイルのパスを設定してみてください。
大抵の方は以下のどちらかと思います。

  • C:\Users\<ユーザ名>\.ssh\config
  • C:\ProgramData\ssh\ssh_config

ただ環境によって異なる場合もありますので、適宜置き換えて設定ください。
ssh構成ファイルのパスについては、リモートエクスプローラのギア(SSH構成ファイルを開く)アイコンをクリックすると、先程作成したssh構成ファイルのパスを確認することが出来ます。
step_00_prepro_ssh_13_troubleshoot.PNG

確認② ssh.exeのパス設定

ssh接続にはsshの実行ファイル(ssh.exe)が必要です。
Windows10(ビルド1809以降)はOpenSSHがインストール済で環境変数にパスが登録されているはずですので、Windowsの「システムのプロパティ」->「環境変数…」を確認してみてください。
(私の環境では「システム環境変数」に登録されていました)

このとき環境変数にOpenSSHのパスが見当たらない場合や、OpenSSHのパスは登録されているがうまくいかない場合は、個別にVSCodeの設定にてOpenSSHのパス設定することで問題が解決するかもしれません。
設定手順ですが、「確認①-ssh構成ファイルのパス設定」のssh接続に関連する設定情報を確認するところまで同じです。設定情報の中の「Remote.SSH: Path」にssh.exeまでの絶対パスを設定してください。

step_00_prepro_ssh_12_troubleshoot.PNG

コンテナへのアタッチ

サーバへのssh接続が完了したので、次はコンテナへアタッチします。
以下の操作はサーバへssh接続したVSCodeにて行ってください。

  1. 「リモートエクスプローラ」のアイコンをクリックします。
    step_02.PNG

  2. 表示されたドロップダウンリストをクリックします。
    step_03-0.PNG

  3. ドロップダウンリストの「開発コンテナー」をクリックします。
    step_03.PNG

  4. 下図のように表示されるため、「更新」をクリックする
    step_05.PNG

  5. パスワードの入力を求められるため、接続先サーバへのログインパスワードを入力してください。
    step_06.PNG

  6. 接続可能なコンテナのリストが表示されるため、任意のコンテナ(今回の場合、test_container)を選択し、右クリックします。「現在のウィンドウでアタッチする」か「新しいウィンドウでアタッチする」を選択してクリックしてください。
    step_07.PNG

    このとき、次のように警告のダイアログが表示される場合がありますが、ダイアログに記載のとおりアタッチするコンテナが信頼できる事を確認したうえで「了解」をクリックするようにしてください。
    step_07_2.PNG

  7. 再度パスワード入力を求められるため、接続先サーバへのログインパスワードを入力してください。
    step_08.PNG

  8. 暫く待つとコンテナへの接続が完了します。
    右下にカーソルをあてると接続先コンテナの情報を確認できます。
    step_09.PNG

以降は通常のPC内の開発環境と同様に扱う事ができます。
例えばPython開発を行いたい場合は、コンテナにアタッチ後、VSCodeの拡張機能「Python」をインストールするなどを実施してください。

免責事項

本記事の掲載にあたり、記事内容について精査・確認をしておりますが、ご利用による損害などが発生したとしても、筆者および筆者の所属組織は責任を負うものではありません。
自己責任の範疇でご利用ください。

今回の記事は以上になります。
最後まで読んでいただき、ありがとうございました!

今後も機械学習の活用を始め、開発環境やシミュレーションなど幅広く技術情報発信をしていく予定です!
最後になりますが、本記事の内容に誤りなどあれば、コメントにてご教授お願いいたします。

5
5
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
5