はじめに
前回はdevcontainer
を使ってみる記事だったので、今回は実際に使っているHugo
のブログ開発環境にdevcontainer
を入れてみる。
環境
1
2
3
| Windows 11 Professional
WSL2 Ubuntu24.04 LTS
Visual Studio Code 1.92.0
|
準備
がインストール済みであること。
devcontainer.jsonの作成
プロジェクトルートに以下を作成した。
docker-in-docker
で動作させるため、その設定を入れている。
開発コンテナには拡張機能くらいしか入れる予定はないので、イメージについては一考の余地あり。
.devcontainer/devcontainer.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
| // For format details, see https://aka.ms/devcontainer.json. For config options, see the
// README at: https://github.com/devcontainers/templates/tree/main/src/go
{
"name": "Go",
// Or use a Dockerfile or Docker Compose file. More info: https://containers.dev/guide/dockerfile
"image": "mcr.microsoft.com/devcontainers/go:1-1.22-bookworm",
// Features to add to the dev container. More info: https://containers.dev/features.
"features": {
"docker-in-docker": {
"version": "latest"
}
},
"runArgs": [
"--init"
],
"mounts": [
"type=bind,source=${localEnv:HOME}/.ssh,target=/home/vscode/.ssh,readonly"
],
// Use 'forwardPorts' to make a list of ports inside the container available locally.
// "forwardPorts": [],
// Use 'postCreateCommand' to run commands after the container is created.
// "postCreateCommand": "go version",
// Configure tool-specific properties.
// "customizations": {},
// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root.
// "remoteUser": "root"
}
|
作成後、再度プロジェクトを開きなおすと、開発コンテナでワークスペースを開くかを聞かれるので、「開く」を選択する。
これで完了。
一通り作業をしてみて、トラブルがあったのでそれも記載しておく。
トラブル
Git pushできない
devcontainer.json
をリモートにプッシュしようとしたが失敗した。
1
2
3
4
5
6
| > git pull --tags origin master
[email protected]: Permission denied (publickey).
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
|
開発コンテナ上でSSHのKeyがないことが原因と思われる。
調べてみたところ、ssh-agent
を使う方法があるようだった。
ただ、今回は devcontainer.json
に以下を追加することで解決した。
1
2
3
| "mounts": [
"type=bind,source=${localEnv:HOME}/.ssh,target=/home/vscode/.ssh,readonly"
],
|
参考
参考
おわりに
devcontainer
もっと積極的に使っていくために、ブログの開発環境に入れてみた。
今後これをもっと使っていこう。