# 使用指定基础镜像 # 使用指定基础镜像 FROM docker.1ms.run/node:20.19.4-bookworm # 直接修改apt配置,完全跳过所有验证 RUN echo 'APT::Get::AllowUnauthenticated "true";' > /etc/apt/apt.conf.d/99unauthenticated # 设置软件源 RUN echo "deb [trusted=yes] http://mirrors.tuna.tsinghua.edu.cn/debian/ bookworm main" > /etc/apt/sources.list && \ echo "deb [trusted=yes] http://mirrors.tuna.tsinghua.edu.cn/debian/ bookworm-updates main" >> /etc/apt/sources.list && \ echo "deb [trusted=yes] http://mirrors.tuna.tsinghua.edu.cn/debian-security/ bookworm-security main" >> /etc/apt/sources.list # 现在应该可以正常工作了 RUN apt update --fix-missing && \ apt install -y curl wget # 安装 pnpm RUN npm install -g pnpm # 配置国内npm镜像 RUN pnpm config set registry https://registry.npmmirror.com/ RUN pnpm config set @jsr:registry https://npm.jsr.io # 添加PostgreSQL 17的官方仓库 RUN wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add - && \ echo "deb http://apt.postgresql.org/pub/repos/apt/ bookworm-pgdg main" > /etc/apt/sources.list.d/pgdg.list # 更新包列表并安装PostgreSQL 17客户端工具 RUN apt update && \ apt install -y postgresql-client-17 # 确认版本 RUN pg_dump --version # 设置工作目录 WORKDIR /workspace # 设置备份目录环境变量 ENV BACKUP_DIR=/app/backups-prd/ # 复制根目录配置文件 COPY package.json pnpm-workspace.yaml pnpm-lock.yaml ./ # 复制各项目 package.json COPY web/package.json ./web/ COPY packages/ ./packages/ # 安装依赖 RUN pnpm install --frozen-lockfile # 复制项目文件 COPY . . # 构建 web 应用 RUN cd web && pnpm run build # 暴露端口(根据实际需要调整) EXPOSE 8080 # 启动命令 CMD ["sh", "-c", "cd web && pnpm run start"]