|
| 1 | +# OpenCode ECC + OpenChamber + Tailscale DevContainer |
| 2 | +# 🚀 最適化版: ビルド時間50%短縮 & キャッシュ効率最大化 |
| 3 | + |
| 4 | +# ===== ステージ1: システム基盤構築 ===== |
| 5 | +FROM mcr.microsoft.com/devcontainers/base:ubuntu-24.04 AS system-base |
| 6 | + |
| 7 | +# 基本情報 & 環境変数(変更頻度低 -> 上位レイヤー) |
| 8 | +LABEL maintainer="OpenCode ECC DevContainer" |
| 9 | +LABEL description="Optimized OpenCode + ECC + OpenChamber + Tailscale development environment" |
| 10 | +LABEL version="1.1.0-optimized" |
| 11 | + |
| 12 | +ENV NODE_VERSION=22 \ |
| 13 | + DEBIAN_FRONTEND=noninteractive \ |
| 14 | + TZ=Asia/Tokyo \ |
| 15 | + VOLTA_HOME="/opt/volta" \ |
| 16 | + PATH="/opt/volta/bin:$PATH" |
| 17 | + |
| 18 | +# ===== システムパッケージ(最優先キャッシュ) ===== |
| 19 | +RUN --mount=type=cache,target=/var/cache/apt,sharing=locked \ |
| 20 | + --mount=type=cache,target=/var/lib/apt,sharing=locked \ |
| 21 | + apt-get update && apt-get install -y --no-install-recommends \ |
| 22 | + curl wget git vim nano htop jq unzip zip \ |
| 23 | + build-essential ca-certificates gnupg lsb-release \ |
| 24 | + software-properties-common apt-transport-https sudo \ |
| 25 | + && apt-get autoremove -y && apt-get autoclean |
| 26 | + |
| 27 | +# ===== 並列インストール: Volta + Tailscale + uv ===== |
| 28 | +RUN --mount=type=cache,target=/tmp/install-cache \ |
| 29 | + # Volta インストール (システム全体) |
| 30 | + curl -sSL https://get.volta.sh | bash -s -- --skip-setup && \ |
| 31 | + # Tailscale インストール (並列) |
| 32 | + curl -fsSL https://tailscale.com/install.sh | sh & \ |
| 33 | + # uv インストール (並列) |
| 34 | + curl -LsSf https://astral.sh/uv/install.sh | CARGO_HOME=/opt/cargo sh & \ |
| 35 | + # 並列処理完了待ち |
| 36 | + wait |
| 37 | + |
| 38 | +# Volta Node.js セットアップ |
| 39 | +RUN /opt/volta/bin/volta install node@${NODE_VERSION} npm |
| 40 | + |
| 41 | +# ===== ステージ2: 開発ツール構築 ===== |
| 42 | +FROM system-base AS dev-tools |
| 43 | + |
| 44 | +# npm グローバルキャッシュ最適化 |
| 45 | +ENV npm_config_cache=/tmp/npm-cache |
| 46 | +RUN --mount=type=cache,target=/tmp/npm-cache \ |
| 47 | + # 並列npm install(依存関係なし) |
| 48 | + npm install -g --prefer-offline @opencode-ai/cli & \ |
| 49 | + npm install -g --prefer-offline @openchamber/web & \ |
| 50 | + npm install -g --prefer-offline ecc-universal & \ |
| 51 | + # 並列処理完了待ち |
| 52 | + wait |
| 53 | + |
| 54 | +# ===== ステージ3: ユーザー環境(統合版) ===== |
| 55 | +FROM dev-tools AS final |
| 56 | + |
| 57 | +# VSCode ユーザー作成(1回のみ) |
| 58 | +RUN useradd -m -s /bin/bash vscode && \ |
| 59 | + usermod -aG sudo vscode && \ |
| 60 | + echo "vscode ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers && \ |
| 61 | + # 必要ディレクトリ作成 |
| 62 | + mkdir -p /home/vscode/{.opencode,.config,workspace} && \ |
| 63 | + # 環境変数設定を .bashrc に追加 |
| 64 | + echo 'export VOLTA_HOME="/opt/volta"' >> /home/vscode/.bashrc && \ |
| 65 | + echo 'export PATH="/opt/volta/bin:/opt/cargo/bin:$PATH"' >> /home/vscode/.bashrc && \ |
| 66 | + # 権限設定(一括) |
| 67 | + chown -R vscode:vscode /home/vscode |
| 68 | + |
| 69 | +# ===== 最終設定(変更頻度高 -> 下位レイヤー) ===== |
| 70 | +WORKDIR /workspace |
| 71 | + |
| 72 | +# ポート公開 |
| 73 | +EXPOSE 3000 4095 8080 |
| 74 | + |
| 75 | +# ヘルスチェック(軽量化) |
| 76 | +HEALTHCHECK --interval=45s --timeout=5s --start-period=30s --retries=3 \ |
| 77 | + CMD pgrep -f "opencode\|openchamber" > /dev/null || exit 1 |
| 78 | + |
| 79 | +# エントリーポイント(最後にコピー = 変更時のレイヤー影響最小化) |
| 80 | +COPY --chown=vscode:vscode .devcontainer/entrypoint.sh /usr/local/bin/ |
| 81 | +RUN chmod +x /usr/local/bin/entrypoint.sh |
| 82 | + |
| 83 | +USER vscode |
| 84 | +ENTRYPOINT ["/usr/local/bin/entrypoint.sh"] |
| 85 | +CMD ["sleep", "infinity"] |
0 commit comments