Skip to content

Dev Container based on mcr.microsoft.com/devcontainers/typescript-node (go, python, ruby, desktop-lite, docker-outside-of-docker, git, git-lfs)

License

Notifications You must be signed in to change notification settings

hiro345g/devcon-gnpr

Repository files navigation

devcon-gnpr-202312

Dev Container based on mcr.microsoft.com/devcontainers/typescript-node (go, python, ruby, desktop-lite, docker-outside-of-docker, git, git-lfs)

 これは、gonodepythonruby コマンドが使える簡易デスクトップ環境を提供する開発コンテナー(Dev Container)を簡単に使えるようにしたものです。次の特長があります。

  • VS Code で使える開発コンテナー(Dev Container)
  • Go プログラミングが可能
  • Node.js 環境での TypeScript プログラミングが可能
  • Python プログラミングが可能
  • Ruby プログラミングが可能
  • 開発専用の Web ブラウザ
  • 日本語入力に対応

 devcon-gnpr-202312 を使うと日本語に対応した簡易 Desktop 環境が動く Docker コンテナーが使えるようになります。簡易 Desktop 環境には VNC という仕組みを使って接続して利用できます。利用方法としては Web ブラウザを使う方法、VNC クライアントを使う方法があります。

クライアント URL
Web ブラウザ http://localhost:6080
VNC クライアント vnc://localhost:5901

 VNC 接続をすると、簡易 Desktop 環境で Firefox や Chromium が用意できるようになり、Web アプリの開発などでも利用できるようになります。

devcon-gnpr-202312 で解決できること

 Web アプリ開発時に、普段の Web ブラウザを使っていて、次のような場面で困ったことがありませんか?

  • 開発で使っているキャッシュだけクリアしたい
  • 開発で使っている Cookie だけクリアしたい
  • 開発用のプラグインは開発中だけ有効にしたい

 開発中に利用する Web ブラウザは普段の利用方法とは違った使い方になります。そのため、開発専用の Web ブラウザ環境を用意したいときがあります。Web ブラウザのプロファイル機能を使うと、ある程度は解決するのですが、Docker コンテナーとして用意できるなら、それを使うのも「あり」だろうと考えて、devcon-gnpr-202312 環境を用意しました。

 これを使うと、普段使っているデスクトップ環境から隔離されたコンテナー環境で Firefox や Chromium といった Web ブラウザを使うことができるようになります。隔離された環境なので、例えばホストファイルにステージング環境の IP と実際に使うホスト名のエントリを登録して動作させることもできます。開発中の Web アプリの動作を確認するための専用 Web ブラウザ環境なので、後で正しい IP へ戻すといった作業も発生しません。こういった環境を用意することで、効率よく Web アプリの開発ができるようになります。

 VS Code の Dev Container 拡張機能を基盤としたものなので、Docker ホストマシンから隔離されたコンテナ内で Web アプリの開発を閉じることができます。複数の Web アプリ開発をしている場合、Docker ホストマシンの環境を利用していると、開発する対象の Web アプリを切り替えるときの負担が大きくなります。開発する対象の Web アプリの単位でコンテナ環境を用意すれば、コンテナ内で環境を完結させることができるので、開発する対象の Web アプリを切り替える際の負担が軽減されます。

使用しているもの

 Docker イメージは Docker Hub の https://hub.docker.com/r/hiro345g/devcon-gnpr-202312 で公開されているものを使用します。ちなみに、この GitHub のリポジトリーには、この Docker イメージをビルドするためのファイルも含まれているので、Docker Hub のものを使わずにローカルマシンでビルドしたものを使うこともできます。

 devcon-gnpr-202312 では、https://github.com/devcontainers/images/tree/main/src/typescript-node で公開されている mcr.microsoft.com/devcontainers/typescript-node:18-bookworm の Docker イメージをベースとしています。Feature に https://github.com/devcontainers/features/ で公開されている common-utils、go、ruby、desktop-lite、docker-outside-of-docker、git、git-lfs を指定して Docker イメージを作成しています。

 devcon-gnpr-202312 では、desktop-lite に次の Web ブラウザを追加して使えるようにしてあります。locale 周りの設定もしてあり、追加で fonts-vlgothic フォントもインストールしてあります。

desktop-lite によるデスクトップ環境について

desktop-lite によるデスクトップ環境では、次のソフトウェアが使えるようになっています。

Dev Container について

 Dev Container については、開発が https://github.com/devcontainers でされていますので、そちらをご覧ください。

 ここで用意している docker-compose.yml では、開発するアプリの Git リモートリポジトリを devcon-gnpr-202312 コンテナーの /home/node/workspace (つまり、devcon-gnpr-202312:/home/node/workspace)へクローンして開発することを想定しています。

 また、devcon-gnpr-202312:/home/node/workspace は Docker ボリュームの devcon-gnpr-202312-workspace-data をマウントして使うようになっています。他にも devcon-gnpr-202312-vscode-server-extensions という Docker ボリュームを使うようになっています。

必要なもの

 devcon-gnpr-202312 を動作をさせるには、Docker、Docker Compose、Visual Studio Code (VS Code) 、Docker 拡張機能、Dev Containers 拡張機能が必要です。

Docker

 これらは Docker Desktop をインストールしてあれば使えます。Linux では Docker Desktop をインストールしなくても Docker Engine と Docker Compose だけをインストールして使えます。例えば、Ubuntu を使っているなら Install Docker Engine on Ubuntu を参照してインストールしておいてください。

Visual Studio Code

 VS Code の拡張機能である Docker と Dev Containers を VS Code へインストールしておく必要があります。

動作確認済みの環境

 次の環境で動作確認をしてあります。Windows や macOS でも動作するはずです。

$ cat /etc/os-release 
PRETTY_NAME="Ubuntu 22.04.3 LTS"
NAME="Ubuntu"
VERSION_ID="22.04"
VERSION="22.04.3 LTS (Jammy Jellyfish)"
VERSION_CODENAME=jammy
ID=ubuntu
ID_LIKE=debian
HOME_URL="https://www.ubuntu.com/"
SUPPORT_URL="https://help.ubuntu.com/"
BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/"
PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy"
UBUNTU_CODENAME=jammy

$ docker version
Client: Docker Engine - Community
 Cloud integration: v1.0.35+desktop.5
 Version:           24.0.7
 API version:       1.43
 Go version:        go1.20.10
 Git commit:        afdd53b
 Built:             Thu Oct 26 09:07:41 2023
 OS/Arch:           linux/amd64
 Context:           default

Server: Docker Engine - Community
 Engine:
  Version:          24.0.7
  API version:      1.43 (minimum version 1.12)
  Go version:       go1.20.10
  Git commit:       311b9ff
  Built:            Thu Oct 26 09:07:41 2023
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          1.6.26
  GitCommit:        3dd1e886e55dd695541fdcd67420c2888645a495
 runc:
  Version:          1.1.10
  GitCommit:        v1.1.10-0-g18a0cb0
 docker-init:
  Version:          0.19.0
  GitCommit:        de40ad0

$ docker compose version
Docker Compose version v2.23.3-desktop.2

ファイルの構成

 ファイルの構成は次のようになっています。

devcon-gnpr-202312/
├── .devcontainer/
│   ├── devcontainer.json ... devcon-gnpr-202312 イメージ起動用 devcontainer.json
│   ├── docker-compose.yml ... devcon-gnpr-202312 イメージ起動用 docker-compose.yml
│   └── sample.env  ... .env ファイルのサンプル
├── build_devcon/ ... devcon-gnpr-202312 の Docker イメージをビルドするときに使う
│   ├── .devcontainer/
│   │   ├── Dockerfile ... devcon-gnpr-202312 イメージビルド用 Dockerfile
│   │   ├── devcontainer.json ... devcon-gnpr-202312 イメージビルド用 devcontainer.json
│   │   ├── menu ... FluxBox メニュー用設定ファイル
│   │   ├── node.dot.bashrc ... /home/node/.bashrc 用ファイル
│   │   ├── node.dot.npmrc ... /home/node/.npmrc 用ファイル
│   │   └── startup ... FluxBox 自動起動用設定ファイル
│   └── build.sh ... devcon-gnpr-202312 の Docker イメージをビルドするためのスクリプト(npm exec を使用)
├── workspace_share/ ... Docker ホストとコンテナーとでファイルを共有するためのディレクトリー
│   ├── script/
│   │   └── install_mozc.sh ... mozc インストール用スクリプト
│   └── dev/ ... このコンテナーを使って開発をするときに使用するファイルを置くためのディレクトリー
│       └── dev.code-workspace ... VS Code ワークスペースのサンプル
├── .gitignore
├── docker-compose.yml ... devcon-gnpr-202312 を利用するときに使う
├── LICENSE ... ライセンス
├── README.md  ... このファイル
└── sample.env  ... .env ファイルのサンプル

 この後、リポジトリをクローンもしくはアーカイブファイルを展開した devcon-gnpr-202312 ディレクトリーのパスを ${REPO_DIR} と表現します。

デスクトップ環境

 VNC (Virtual Network Computing) を使ってデスクトップ環境へアクセスします。パスワードは次のとおりです。

  • VNC のパスワード: vscode

 別のパスワードにしたい場合は、「カスタマイズ」の説明にしたがって、Docker イメージの作成時に指定してください。

使い方

 ここでは使い方について説明します。

使う準備

 先に「環境変数」を参照して、必要なら .env ファイルを用意してください。カスタマイズをしたい場合は、「カスタマイズ」を参照して Docker イメージを作成してください。

利用方法

 VS Code を起動し、F1 キーを入力してコマンドパレットを表示してから、「開発コンテナー: コンテナーでフォルダを開く...(Dev Containers: Open Folder in Container...)」をクリックします。フォルダーを選択する画面になるので ${REPO_DIR} を指定して開きます。すると ${REPO_DIR}/.devcontainer/devcontainer.json の指定にしたがって、devcon-gnpr-202312 コンテナーが Dev Container として起動します。このとき、拡張機能なども追加されます。 それから、devcon-gnpr-202312 コンテナー用の VS Code の画面となります。

 つまり、開いている VS Code の画面が、そのまま devcon-gnpr-202312 コンテナー用の VS Code の画面として開き直されます。devcon-gnpr-202312 コンテナーでは Docker ホストのファイルを間違えて操作しないように、${REPO_DIR} は見えないようにしてあります。この方法で開発コンテナーを起動すると、VNC が使えるようになります。docker compose コマンドなどで通常のコンテナーとして起動した場合は、そのままでは VNC サーバーが起動しません。

 起動したら、Web ブラウザから http://localhost:6080 へアクセスします。すると、VNC 接続の画面になるので、「接続」をクリックしてパスワードを入力します。

 VNC クライアントを使う場合は localhost:5901 へアクセスします。パスワードは http://localhost:6080 へアクセスする場合と同じです。接続したら、マウスクリックで表示できるメニューから Firefox や Chromium を起動して使うことができます。

 これで devcon-gnpr-202312 コンテナーで Node.js を使った Web アプリの開発をしつつ、Web ブラウザで動作確認ができます。Docker ホストの環境から隔離されているため、開発している Web アプリの動作確認のための Web ブラウザ用設定がしやすくなります。

コンテナーの停止、削除の仕方

 VS Code の Docker 拡張機能の画面で、CONTAINERS の欄に表示されている devcon-gnpr-202312 のコンテキストメニューから Compose Stop でコンテナー停止、Compose Down でコンテナー削除ができます。

日本語入力

 Docker イメージ作成直後は日本語入力ができません。インストール時に GUI が必要だからです。コンテナー起動後に、ibus-mozc をインストールすると日本語入力ができるようになります。インストール用スクリプトをコンテナー内の /share/script/install_mozc.sh で参照できるようにしてあるので、日本語入力が必要な場合は、VNC 接続してターミナルを起動し、次のように実行します。

sh /share/script/install_mozc.sh

 「dbus-launch --autolaunch=(略)」のエラーが発生しますが無視して大丈夫です。

 次に画面右下隅の EN のアイコン(IBus のアイコン)を右クリックして表示されるメニューで「Restart」します。それから、同じメニューにある「Preference」をクリックします。

 表示された「IBuss Preference」画面の「Input Method」タブを表示し、「Add」をクリックします。一覧で「Japanese」をクリックし、表示された選択肢の中から「Mozc」を選択肢て「Add」をクリックします。これで日本語入力ができる環境の準備は終わりで、IBus のアイコンから Mozc の入力を切り替えることができるようになります。

 なお、 mozc の設定をする場合は下記のコマンドを実行します。

/usr/lib/mozc/mozc_tool --mode=config_dialog

 入力の切り替えについては、画面右下隅の IME のアイコンをクリックして表示されるメニューを使います。

noVNC での日本語入力

 noVNC では「半角/全角」キーの入力が効かないので、英語と日本語の入力を切り替えするときに戸惑うでしょう。

 ショートカットキーで IME の切り替えができるので、それを使います。初期値は「Superspace」となっていて、「Windowsキーとスペースキーの同時入力」で切り替えができます。日本語入力をしたい場合は Mozc、英語入力をしたい場合は、English の IME を使います。Mozc は「ひらがな」の入力設定にしておきます。

 ショートカットキーの変更は、「IBuss Preference」画面の「General」タブの「Keyboard Shortcuts」にある「Next input method:」で英語と日本語のIME 利用切り替えのショートカットを指定できます。ここを「<Shift>space」などに変更することもできます。

 IBus の設定を保存しておく場合は、下記のコマンドを使います。

dconf dump /desktop/ibus/ > /share/ibus.dconf

 保存した設定を反映するには、下記のようにします。

dconf load /desktop/ibus/ < /share/ibus.dconf

 ショートカットーキーを「Superspace」以外にするなら、IBus の設定ではなく、Mozc の設定の方でもできます。IBus のアイコンをクリックすると表示されるメニューで「Japanese - Mozc」を選択した状態にしていると、「ツール」-「プロパティ」というメニューが表示されるので、これをクリックすると Mozc Settings の画面が表示されます。この画面の「General」タブにある「Keymap」の「Customize...」をクリックすると「Mozc keymap editor」の画面が表示されて、ショートカットキーの調整ができます。ここで、IME の切り替え用ショートカットを調整することを検討してみると良いでしょう。

 たとえば、「Shift + Space」キーの入力で切り替えするのであれば、次のようにします。「Mozc keymap editor」の画面で、「Edit」-「New entry」で下記のキーを追加します。

  • Mode: DirectInput
  • Key: Shift Space
  • Command: Activate IME

 既存の下記のキーマップを「→」のように変更します。

  • Mode: Precomposition
  • Key: Shift Space
  • Command: Insert alternate space → Deactivate IME

 IBus アイコンの右クリックメニューで「Restart」をクリックして再起動します。これで「Shift + Space」キーの入力で、入力モードの「直接入力」と「ひらがな」を切り替えできるようになります。ただし、これらのショートカットの設定前に起動していたアプリケーションでは有効にならないので、その場合はアプリケーションも再起動してください。

フォント

 フォントは fonts-vlgothic パッケージを使っています。Noto にしたい場合は、devcon-gnpr-202312:/share/fonts-noto-cjk-conf/local.confdevcon-gnpr-202312:/etc/fonts/local.conf へコピーします。

sudo cp /share/fonts-noto-cjk-conf/local.conf /etc/fonts/local.conf

 ファイルの作成後、fonts-noto-cjk をインストールします。fc-cache でキャッシュクリア、fc-match でデフォルトフォントの確認をします。

$ sudo apt -y install fonts-noto-cjk fonts-noto-cjk-extra
(略)
$ fc-cache -v
(略)
$ fc-match
NotoSansCJK-Regular.ttc: "Noto Sans CJK JP" "Regular"

 IBus のアイコンで Restart をすると IBus のメニューへも反映されます。

devcon-gnpr-202312-mozc

 この Docker イメージを使い続ける場合は、タグをつけておくなどして、再利用できるようにしておくと良いでしょう。

 タグをつける前に、タグをつけた Docker イメージを利用する devcon-gnpr-202312-mozc ディレクトリーを次のようにして用意します。ここでは ${BASE_DIR}${REPO_DIR}/workspace_share ディレクトリーだとしています。

#!/bin/sh
BASE_DIR=$(cd $(dirname $0)/..;pwd)
DEV_DIR=${BASE_DIR}/dev
DIST_DIR=${BASE_DIR}/devcon-gnpr-202312-mozc

if [ ! -e ${DEV_DIR}/devcon-gnpr-202312 ]; then
  cd ${DEV_DIR}/
  wget https://github.com/hiro345g/devcon-gnpr-202312/archive/refs/heads/main.zip
  unzip ${DEV_DIR}/main.zip
  mv ${DEV_DIR}/devcon-gnpr-202312-main ${DEV_DIR}/devcon-gnpr-202312
  rm ${DEV_DIR}/main.zip
fi
if [ ! -e ${DIST_DIR}/.devcontainer ]; then mkdir -p ${DIST_DIR}/.devcontainer; fi
if [ ! -e ${DIST_DIR}/workspace_share ]; then mkdir -p ${DIST_DIR}/workspace_share; fi
cp -r ${DEV_DIR}/devcon-gnpr-202312/.devcontainer/* ${DIST_DIR}/.devcontainer/
cp -r ${DEV_DIR}/devcon-gnpr-202312/docker-compose.yml ${DIST_DIR}/
sed -i 's/devcon-gnpr-202312/devcon-gnpr-202312-mozc/' ${DIST_DIR}/.devcontainer/devcontainer.json
sed -i 's/devcon-gnpr-202312/devcon-gnpr-202312-mozc/' ${DIST_DIR}/docker-compose.yml

rm -fr ${DEV_DIR}/devcon-gnpr-202312

 この処理と同じ動作をするスクリプトを ${REPO_DIR}/workspace_share/script/create-devcon-gnpr-202312-mozc.sh に用意してあります。これを devcon-gnpr-202312 コンテナーの中で実行します。

sh /share/script/create-devcon-gnpr-202312-mozc.sh

 すると、devcon-gnpr-202312-mozc ディレクトリー(コンテナー内だと devcon-gnpr-202312:/share/workspace_share/devcon-gnpr-202312-mozc ディレクトリー、Docker ホストだと ${REPO_DIR}/workspace_share/devcon-gnpr-202312-mozc ディレクトリー)が作成されます。

 利用するときに使えるファイルが用意できたら、イメージにタグをつけます。タグをつける場合は、次のようにします。

docker compose -p devcon-gnpr-202312 stop devcon-gnpr-202312
docker commit devcon-gnpr-202312 devcon-gnpr-202312-mozc:1.0

 この後に devcon-gnpr-202312-mozc:1.0 を使ってコンテナーを起動する場合は、devcon-gnpr-202312 コンテナーは削除しておます。

docker compose -p devcon-gnpr-202312 down

 devcon-gnpr-202312-mozc:1.0 イメージを使って devcon-gnpr-202312-mozc コンテナーの Dev Container を起動するときは、Docker ホストの VS Code で devcon-gnpr-202312-mozc ディレクトリーを開きます。devcon-gnpr-202312-mozc ディレクトリーは devcon-gnpr-202312 ディレクトリーと同じディレクトリー階層へ移動して使うと管理しやすいでしょう。

 具体的なコマンドは次のようになります。

cd ${REPO_DIR}/..
mv ./devcon-gnpr-202312/workspace_share/devcon-gnpr-202312-mozc .

 必要なら ${REPO_DIR}/.env ファイルを用意します。準備ができたら、VS Code で devcon-gnpr-202312-mozc ディレクトリーを開きます。

code devcon-gnpr-202312-mozc

 これで「Reopen in Container」の通知が表示されるので、「Reopen in Container」をクリックします。VS Code がコンテナーに接続した状態になったら、作業ができるようになります。

 以上で、mozc がインストールされた状態の devcon-gnpr-202312 が使えるようになります。

npm 用環境変数の設定

 npm 用環境変数の設定は devcon-gnpr-202312 コンテナーの /home/node/workspace/.npmrc に指定するようにしてあります。これは docker-compose.yml の環境変数 NPM_CONFIG_USERCONFIG を使っています。.env ファイル内の NPM_CONFIG_USERCONFIG の指定を変更することで、この環境変数の値を変更して、自分で用意した .npmrc ファイルを使えるようになります。npm 用環境変数の設定を変更したい場合は、この機能を使ってください。

 なお、初期設定では、開発コンテナーのユーザー node が npm パッケージをグローバルにインストールできるようにするため、.npmrc ファイルには、次のような指定をしてあります。

prefix=/home/node/workspace/.npm-global

 このため、グローバルにインストールした npm パッケージは /home/node/workspace/.npm-global の下にインストールされます。

 ちなみに、.npmrc で指定した prefix の値を変更したいだけの場合は、docker-compose.ymlenvironment: へ環境変数 NPM_CONFIG_PREFIX を追加して指定することもできます。その場合は環境変数 NPM_CONFIG_USERCONFIG の方は無効化しておくと無難です。

カスタマイズ(ビルド)

 デフォルトでは、Docker Hub で公開してあるビルド済みのものを使っていますが、このイメージをカスタマイズしたものを使うこともできます。${REPO_DIR}/build_devcon にあるものを使います。

 カスタマイズしたイメージを使用するにはビルドが必要です。Dev Container 環境を起動する度に自動でビルドを実行する必要はないので、ビルド作業を別にしてあります。実行時用のものと似たような docker-compose.yml を用意することになりますが、こうしておいた方が Docker イメージのタグ名指定が設定ファイルで明示的にわかるようになります。また、意図しない更新も入りにくくなり、利用時に安定します。

 自分でビルドをする場合は次の2つの方法があります。

  • VS Code を使う方法
  • build.sh を使う方法

 カスタマイズは ${REPO_DIR}/build_devcon/ にある .devcontainer/devcontainer.jsonDockerfile を修正してください。必要なら、他のファイルもカスタマイズしてください。

 この後、次の順に説明します。

  • ビルドの準備
  • VS Code を使ったビルド方法
  • build.sh を使ったビルド方法
  • VNC Server のパスワード、ポート番号の変更
  • hiro345g/devcon-gnpr-202312:1.0 へ戻す方法
  • カスタムイメージの削除方法

ビルドの準備

 最初にビルド済みの hiro345g/devcon-gnpr-202312:1.0 をダウンロードしておきます。次のように docker pull コマンドを実行します。

docker pull hiro345g/devcon-gnpr-202312:1.0

 基本は、これをカスタマイズすることになります。

 次に ${REPO_DIR}/build_devcon/ にある .devcontainer/devcontainer.jsonDockerfile を修正してください。必要なら、他のファイルもカスタマイズしてください。

 この後、devcon-gnpr-202312-custom:1.0 のカスタムイメージを作成する方法を説明します。

VS Code を使ったビルド方法

 VS Code を起動してから、F1 キーを入力して VS Code のコマンドパレットを表示します。入力欄へ「dev containers open」などと入力すると「開発コンテナー: コンテナーでフォルダを開く...(Dev Containers: Open Folder in Container...)」が選択肢に表示されます。これをクリックすると、フォルダーを選択する画面になるので ${REPO_DIR}/build_devcon を指定して開きます。

 vsc-build_devcon- で始まる Docker イメージが作成されてコンテナーが起動します。vsc-build_devcon- で始まる Docker イメージに devcon-gnpr-202312:1.0 のタグをつけます。

 例えば、次の例だと vsc-build_devcon-b3ed032a709b975173b2f2fcf5212c79-uid といったイメージが作成されたので、それに対して devcon-gnpr-202312-custom:1.0 のタグをつけています。

$ docker container ls |grep vsc
351cab45fe6c   vsc-build_devcon-b3ed032a709b975173b2f2fcf5212c79-uid   (略)
$ docker tag vsc-build_devcon-b3ed032a709b975173b2f2fcf5212c79-uid devcon-gnpr-202312-custom:1.0

 使用する Docker イメージを作成した devcon-gnpr-202312-custom:1.0 へ変更する必要があるので、${REPO_DIR}/docker-compose.yml を次のように編集します。

name: devcon-gnpr-202312
services:
  devcon-gnpr-202312:
    #image: hiro345g/devcon-gnpr-202312:1.0
    image: devcon-gnpr-202312-custom:1.0
    container_name: devcon-gnpr-202312
    (略)

build.sh を使ったビルド方法

 ${REPO_DIR}/build_devcon/build.sh スクリプトを実行すると、カスタム Docker イメージをビルドしてタグ devcon-gnpr-202312:1.0 をつけることができます。

 build.sh スクリプトを利用するには、npm コマンド、docker コマンドが実行できる環境が必要です。内部的に @devcontainers/clinpm exec コマンドで実行しています。

cd ${REPO_DIR}
sh ./builde_devcon/build.sh

 カスタマイズしたことがわかるように build.sh で作成した devcon-gnpr-202312:1.0 イメージに devcon-gnpr-202312-custom:1.0 のタグをつけます。

docker image tag hiro345g/devcon-gnpr-202312:1.0 devcon-gnpr-202312:1.0

 devcon-gnpr-202312:1.0 のイメージタグは必要ないので docker image rm コマンドで削除します。

docker image rm devcon-gnpr-202312:1.0

 使用する Docker イメージを作成した devcon-gnpr-202312-custom:1.0 へ変更する必要があるので、${REPO_DIR}/docker-compose.yml を次のように編集します。

name: devcon-gnpr-202312
services:
  devcon-gnpr-202312:
    #image: hiro345g/devcon-gnpr-202312:1.0
    image: devcon-gnpr-202312-custom:1.0
    container_name: devcon-gnpr-202312
    (略)

VNC Server のパスワード、ポート番号の変更

 パスワード、Web版VNC Client用ポート番号、VNC Viewer用ポート番号を変更したい場合は、build/.devcontainer/devcontainer.json 内のファイルを編集して、"ghcr.io/devcontainers/features/desktop-lite:1": のオプションで指定できます。

"features": {
    "ghcr.io/devcontainers/features/desktop-lite:1": {
        "password":"vscode",
        "webPort":"6080",
        "vncPort":"5901",
    }
}

hiro345g/devcon-gnpr-202312:1.0 へ戻す方法

hiro345g/devcon-gnpr-202312:1.0 へ戻すには、${REPO_DIR}/docker-compose.yml を次のように編集します。

name: devcon-gnpr-202312
services:
  devcon-gnpr-202312:
    image: hiro345g/devcon-gnpr-202312:1.0
    #image: devcon-gnpr-202312-custom:1.0
    container_name: devcon-gnpr-202312
    (略)

カスタムイメージの削除方法

 カスタムイメージの削除方法について説明します。

 一度のビルドで、想定していた使い方ができるカスタムイメージができるのが理想です。ところが、作成したカスタムイメージを動かしてみると、想定していなかった不具合が出てくるなど、うまくいかないことの方が多いものです。そういったときは、カスタムイメージの作り直しをすることになり、その際に作成済みのカスタムイメージを削除したいことがあります。

 カスタムイメージを削除したい場合は、docker image rm コマンドで削除します。

docker image rm devcon-gnpr-202312-custom:1.0

環境変数

 .env ファイルを用意すると docker-compose.yml 内の ${変数名} で指定されているものを、.env で指定したものへ変更できます。具体的な指定方法は sample.env ファイルを参考にしてください。

 コンテナーと Docker ホストとでファイルを手軽に参照したり転送したりできるように、devcon-gnpr-202312:/share をバインドマウントするようにしています。Docker ホスト側で使用するディレクトリーを SHARE_DIR で指定します。Docker ホスト側に存在するものを指定してください。ここでは、あらかじめ workspace_share ディレクトリーを用意してあり、それを使っています。

 これを変更することができるように、環境変数 SHARE_DIR を用意してあります。次の例では ${REPO_DIR}/share ディレクトリーを作成して、それを使うようにしています。

cd ${REPO_DIR}
mkdir share
echo 'SHARE_DIR=./share' > .env

About

Dev Container based on mcr.microsoft.com/devcontainers/typescript-node (go, python, ruby, desktop-lite, docker-outside-of-docker, git, git-lfs)

Resources

License

Stars

Watchers

Forks

Packages

No packages published