44 lines
1.4 KiB
Docker
44 lines
1.4 KiB
Docker
FROM fedora:latest
|
|
|
|
# 1. 基础工具 (包含 Zed 远程运行所需的 procps-ng, tar)
|
|
RUN dnf update -y && dnf install -y \
|
|
curl git wget unzip procps-ng tar gzip shellcheck vim\
|
|
gcc gcc-c++ make cmake openssl-devel tmux jq\
|
|
zsh sudo python3 python3-pip openssh-server \
|
|
&& dnf clean all
|
|
|
|
# 2. 环境变量
|
|
ENV CARGO_HOME=/usr/local/cargo \
|
|
RUSTUP_HOME=/usr/local/rustup \
|
|
BUN_INSTALL="/root/.bun"
|
|
ENV PATH="$BUN_INSTALL/bin:/usr/local/cargo/bin:${PATH}"
|
|
RUN chsh -s /bin/zsh root
|
|
|
|
# 3. 安装 Rust & Bun
|
|
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
|
|
RUN curl -fsSL https://bun.sh/install | bash
|
|
|
|
# 4. 全局安装 AI 工具
|
|
RUN bun install -g opencode-ai
|
|
|
|
# 5. SSH & 目录预设 (为 Zed 准备)
|
|
RUN ssh-keygen -A && \
|
|
mkdir -p /root/.zed /root/.local/share/zed && \
|
|
sed -i 's/#PermitRootLogin prohibit-password/PermitRootLogin yes/' /etc/ssh/sshd_config
|
|
|
|
RUN sed -i 's/#PermitUserEnvironment no/PermitUserEnvironment yes/' /etc/ssh/sshd_config
|
|
# 6. Shell 美化
|
|
RUN sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" "" --unattended
|
|
|
|
# 接收来自 compose 的参数
|
|
ARG CONTAINER_WORKSPACE=/workspace
|
|
|
|
# 设置工作目录
|
|
WORKDIR ${CONTAINER_WORKSPACE}
|
|
|
|
COPY entrypoint.sh /usr/local/bin/entrypoint.sh
|
|
RUN chmod +x /usr/local/bin/entrypoint.sh
|
|
|
|
ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]
|
|
CMD ["zsh"]
|