8
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

VSCodeリモートコンテナで、簡単にPythonの環境構築をする方法

Last updated at Posted at 2022-09-20

1. 目的

この記事の目的は、VSCodeのリモートコンテナでPython環境を構築し、楽に開発・学習を行えるようにすることです。

この記事を参照するメリットは以下の点があります。

  • ローカルPCの環境を汚さない、仮装環境を簡単に構築できる
  • VSCodeの拡張機能を仮想環境内で使うことができる

2. 事前準備

必要な事前準備は以下のようになります。

2-1. VSCodeと拡張機能のインストール

以下のページを参考に、VSCodeと拡張機能をインストールしてください。

必要な拡張機能

2-2. Docker Desktopのインストール

以下のページを参考にDocker Desktopをインストールしてください。

Windouwの方への注意
ドキュメント内のSystem requirementsに記述されているように、 以前のバージョンの WSL の手動インストール手順に従って、WSL2を用意してから、Docker Desktopをインストールしてみてください。

3. ディレクトリとファイルの作成

以下では、VSCodeのリモートコンテナでPython環境を構築するために必要なディレクトリ、ファイルを作成します。

私のGitHubで、今回作成するファイルを公開しています。もしよろしければ参考にしてください。

cloneで複製していただいても大丈夫です。

$ git clone https://github.com/Mochi-Moch1/vscode-remote-container-python.git

3-1. ディレクトリの作成

以下のようなディレクトリ構造を作成していきます。
親となるディレクトリ(vscode-remote-container-python)は好きな場所に作っていただいて大丈夫です。

vscode-remote-container-python
┝ .devcontainer 
│   └ devcontainer.json
┝ Dockerfile
┝ reqirements.txt
┝ docker-compose.yml

3-2. devcontainer.json ファイルの作成

.devcontainer の中に以下のようなファイルを作成します。

devcontainer.json
{
	"name": "remote python3",
    "dockerComposeFile": "../docker-compose.yml",
    "service": "python3", 
	"workspaceFolder": "/workspace",
    "shutdownAction": "stopCompose",
    "extensions": ["ms-python.python"]
}

devcontainer.json はコンテナへのアクセス方法を伝え、VSCodeとコンテナを繋ぐ役目があります。

各項目を説明します。

  1. "name": "remote python3"

    • 今回作るコンテナの名前です。
  2. "dockerComposeFile": "../docker-compose.yml"

    • 参照するDocker Composeファイルへのパスを示します。パスはdevcontainer.jsonからの相対パスで与えます。
    • Docker Composeを使う場合には必須です。
  3. "service": "python3"

    • devcontainer.jsonで扱うDocker Compose内のサービスを与えます。
    • 基本は1つのdevcontainer.jsonで一つのサービスを扱います。
    • Docker Composeを使う場合には必須です。
  4. "workspaceFolder": "/workspace"

    • リモートコンテナに接続したときにデフォルトで開く、ファイルのパスを与えます。
  5. "shutdownAction": "stopCompose"

    • リモートコンテナのウィンドウを閉じた時の処理を与えます。
    • stopComposeでは、composeごと停止します。
  6. "extensions": ["ms-python.python"]

    • リモートコンテナ内でダウンロードしたいVSCodeの拡張機能を与えます。
    • ローカルコンピュータのVSCodeの拡張機能には、影響を与えません。

3-3. Dockerfileの作成

以下に今回作成するコンテナのDockerfileを示します。

FROM python:3.10.6
# Latest version in 2022.9.1

RUN python -m pip install --upgrade pip

WORKDIR /workspace

COPY requirements.txt /workspace/

RUN pip install -r requirements.txt

ENV JUPYTER_ENABLE_LAB = yes

Dockerfileは1つのコンテナを作成するために使うファイルです。

各項目を説明します。

  1. FROM python:3.10.6

    • コンテナの元となるimageを指定します
    • 使いたいPythonのバージョンがある方は、こちらを変更してください
  2. RUN python -m pip install --upgrade pip

    • pipのインストールとアップデートを行います
  3. WORKDIR /workspace

    • Dockerfileが扱う作業ディレクトリを/workspaceに移動します
  4. COPY requirements.txt /workspace/

    • requirements.txtをコンテナ内の/workspace/直下にコピーします
  5. RUN pip install -r requirements.txt

    • ライブラリのインストールを行います
    • インストールしたいものは、後に説明するrequirements.txtに記述します
  6. ENV JUPYTER_ENABLE_LAB = yes

    • Jupyter labを使うために、環境変数を変更します

requirements.txtの作成

以下に今回作成するrequirements.txtを示します。

requirements.txt
NumPy==1.23.2 
jupyterlab==3.4.5 

このファイルには、コンテナ内にインストールしたいライブラリを記述しておきます。(@shun198 さんに教えていただきました)

バージョンの指定は必須ではありません。ただし、指定しておく事で環境の統一化がしやすくなります。

3-4. docker-compose.ymlの作成

docker-compose.yml
version: '3'
services:
  python3:
    build:
      context: .
      dockerfile: Dockerfile
    tty: true
    volumes:
    - workspace:/workspace
    ports:
      - '1000:8888'

volumes:
  workspace:
    #  driver_opts:
    #        type: none
    #        device: absolute path
    #        o: bind

docker-compose.ymlは複数のコンテナを管理し、構築、停止、削除などを行う役割を持ちます。

各項目を説明します。

  1. version: '3'

    • Compose fileのバージョンを与えます
  2. services:
    python3:

    • python3という名前のサービスを作成します
      • サービスは一つのコンテナのようなイメージです
  3. build:
    context: .
    dockerfile: Dockerfile

    • コンテナを作成するためのDockerfileへのパスを指定します
  4. tty: true

    • コンテナ側に仮想端末を置くことで、コンテナを正常終了させず、持続させます
  5. volumes:
    -workspace:/workspace

    • workspaceという名前のvolumeに場所/workspaceを与えます
      • volumeはデータを保存しておく場所のようなイメージです
      • ウィンドウを閉じてもデータが保持されます
  6. ports:
    -'1000:8888'
    * ポートを指定します

    • 左(1000)はホストのポート
    • 右(8888)はコンテナのポート
  7. volumes:
    workspace:

    • 先ほど指定したvolumeのworkspaceを再度指定します
      • volumeに名前をつけ、管理を楽にするために必要です

追加情報
自身のパソコンのフォルダやファイルをコンテナ内とつなげたい場合には、コメントアウト(#)を外してください。

そして、device: absolute pathabsolute pathの代わりにつなげたいフォルダなどの絶対パスを指定してください。

これをDockerではバインドマウントと呼びます

4. リモート環境を組み立てる

いよいよVSCodeリモートコンテナを利用して、環境を立ち上げていきます!

4-1. フォルダをコンテナで開ける

  1. VSCodeで先ほど作成したフォルダvscode-remote-container-pythonを開いてください。

  2. 左下の緑の部分をクリックしてください

  3. Open Folder in Container をクリックしてください

  4. Openでフォルダvscode-remote-container-pyhtonを開いてください

スクリーンショット 2022-09-19 22.03.00.png

エラーが出た場合

  • ポートに関するエラーが出た場合は、一度作成されたリモートコンテナを削除し、docker-compose.yml内のポート番号(1000)を1001などに変更してください。

  • 修正してうまくいかない場合などは、F1キーを押してRemote Containers : Rebuild and Reopen in Containerを試してみてください。

4-2. カレントディレクトリと拡張機能の確認

まずはカレントディレクトリを確認してみましょう。

以下のコマンドをVSCodeのターミナルに入力してください。

$ pwd

/workspace という出力があるかと思います。

これにより今、workspaceというdevcontainer.json内の"workspaceFolder": "/workspace"で指定したディレクトリにいることが確認できます。

また、ディレクトリの構成からローカル環境ではなく、仮装環境にいることも確認できます。


次に拡張機能を確認してみましょう。

左の拡張機能のタブから、ローカルのVSCode(LOCAL)とは別で、コンテナ内のVSCode(DEV CONTAINER:...)に独自の拡張機能がインストールされていることを確認できます。
スクリーンショット 2022-09-19 22.18.11.png

これにより、この方法では仮装環境の拡張機能もカスタマイズできます。

4-3. Pythonファイルの作成と実行

簡単なpythonファイルを作成し、実行してみましょう。

  1. ファイルを作成します

  2. 名前にhello.pyと入力します
    これでPythonのファイルを作成できます。
    スクリーンショット 2022-09-20 10.16.03.png

  3. ファイルの中に、以下のコードを書きます
    この時、以下の2つを確認できます。

    • VSCodeの補完機能が働いている
    • ライブラリ(numpy)がインストールされている
    import numpy as np
    print("hello remote container")
    
    print(np.zeros(5))
    
  4. VSCodeのターミナルに以下のコマンドを入力する
    先ほど作成したPythonファイルを実行します。

    python3 hello.py
    

    以下のような結果が返ってくるかと思います。

    hello remote container
    [0. 0. 0. 0. 0.]
    

これでPythonファイルの作成と実行は完了です!

補完機能が働くなど、非常に便利に使えます!

4-4. Jupyter Notebookファイルの作成と実行

次にJupyter Notebookのファイルを作成し、実行していきます。

普段Notebook形式を用いている方は、こちらの方が慣れているかもしれません。

  1. ファイルを作成します

  2. 名前にsample.ipynbと入力します
    これでJupyter Notebookのファイルを作成できます。
    スクリーンショット 2022-09-20 10.45.02.png

  3. Pythonのバージョンを変更します
    右上のPython 3..のようなボタンを押し、選択することで、Notebook内で用いるPythonのバージョンを変更できます。

    ここでは右端にGlobal Envと示されているPython 3.10.6を選択してみましょう。
    スクリーンショット 2022-09-20 10.52.44.png

  4. コードセルの中に、以下のコードを書きます
    Pythonファイルと同様に、以下の2つを確認できます。

    • VSCodeの補完機能が働いている
    • ライブラリ(numpy)がインストールされている
    import numpy as np
    print("hello jupyter")
    
    np.ones(5)
    

    スクリーンショット 2022-09-20 10.59.07.png

  5. 実行ボタンを押す
    先ほど作成したコードセルを実行します。
    スクリーンショット 2022-09-20 11.01.05.png
    画像のように、次の出力がされます。

hello jupyter
array([1., 1., 1., 1., 1.])

これでJupyter Notebookファイルの作成と実行は完了です!

こちらでも補完機能が働くなど、非常に便利に使えます!

5. リモートコンテナの終了と再開

次に、リモートコンテナを終了したのち、再開する動きを確認してみましょう。

普段使う際に、重要な部分です。

5-1. リモートコンテナを閉じる

主に2つの方法があります。
devcontainer.jsonのshutdownActionで指定したように、自動的にComposeを停止しますが、保存されているデータは消えません。

  • VSCodeをそのまま閉じたい場合
    ウィンドウを閉じるボタンを押してください。

  • リモートコンテナだけを閉じ、そのままVSCodeを使いたい場合
    1. 左下の緑色のボタンを選択します
    2. Reopen Folder Locallyを選択します
      スクリーンショット 2022-09-20 11.51.55.png
      これで無事にローカルのVSCodeに戻れます。

5-2. リモートコンテナを再開する

再開する方法は主に2つあります。
中に作成したファイルが残っていることも確認してみてください。

  1. 開きたいフォルダが指定してある場合
    最初に作成したvscode-remote-container-pythonフォルダをVSCodeで開いている場合は

    1. 左下の緑のボタンを押す
    2. Reopen in Containerを選択する
      スクリーンショット 2022-09-20 11.57.08.png
      この流れで、リモートコンテナを再開できます。Dockerコンテナの仕組みにより、一度作成した仮装環境は、高速で立ち上げることができます。
  2. フォルダを指定していない場合

    1. 左のRemote Explorerを選択します
    2. CONTAINERS > Dev Containers > workspace vscode-remote-container-python...を右クリックします
    3. Open Folder in Container を選択します
      スクリーンショット 2022-09-20 12.39.30.png

ショートカット
VSCodeを開いた時に表示される、Get Started > Recentの中でも選ぶことができます!

5-3. リモートコンテナを削除する

最後にリモートコンテナを削除する方法を説明します。

もう今回作成した仮装環境を使わない場合に、簡単に削除できます。また、パソコンの容量の削減にもつながります。

  1. ローカルのVSCodeを開きます

  2. 左のRemote Explorerを選択します

  3. CONTAINERS > Dev Containers > workspace vscode-remote-container-python...を右クリックします

  4. Remove Container を選択します

スクリーンショット 2022-09-20 12.39.30.png

注意
この状態ではまだ、内部にあったデータ自体は削除されていません。

完全に内部のデータを消すためには、DEVVOLUMESを削除する必要があります。バインドマウントを用いていない場合は、完全に消えるので気を付けてください。

  1. 左のRemote Explorerを選択します
  2. DEVVOLUMES > workspace vscode-remote-container-python...を右クリックします
  3. Removeを選択します

スクリーンショット 2022-09-20 14.22.33.png

以上でPythonの環境構築は終了です!お疲れ様でした!
快適なコーディングの手助けになれば嬉しいです。

次のステップ

  • 同様の手順でPythonのWebアプリケーションフレームワーク Flaskの環境構築方法も説明しています。Webアプリに興味のある方は、ぜひご覧ください。

参考文献

以下を参考にさせていただきました。

読んでいただき、ありがとうございました!

8
8
4

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
8
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?