源修改
This commit is contained in:
58
build.sh
58
build.sh
@@ -335,11 +335,15 @@ save_image() {
|
||||
}
|
||||
|
||||
# ================================================
|
||||
# 主流程控制
|
||||
# 主流程控制(函数化)
|
||||
# ================================================
|
||||
|
||||
git_update_if_needed() {
|
||||
# Git更新(可选)
|
||||
if [ "${DO_BUILD}" = true ]; then
|
||||
if [ "${DO_BUILD}" != true ]; then
|
||||
return
|
||||
fi
|
||||
|
||||
log_step "Git Pull"
|
||||
cd "${PROJECT_ROOT}"
|
||||
|
||||
@@ -356,20 +360,29 @@ if [ "${DO_BUILD}" = true ]; then
|
||||
git pull origin main 2>/dev/null || git pull origin master 2>/dev/null || true
|
||||
fi
|
||||
echo ""
|
||||
}
|
||||
|
||||
run_compile() {
|
||||
# 执行编译
|
||||
if [ "${DO_BUILD}" != true ]; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 执行编译
|
||||
if [ "${DO_BUILD}" = true ]; then
|
||||
case ${BUILD_TARGET} in
|
||||
serv|all)
|
||||
serv)
|
||||
compile_serv
|
||||
;;
|
||||
web)
|
||||
compile_web
|
||||
;;
|
||||
all)
|
||||
compile_serv
|
||||
;& # fallthrough
|
||||
web|all)
|
||||
compile_web
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
}
|
||||
|
||||
run_build_images() {
|
||||
# 执行镜像构建
|
||||
case ${BUILD_TARGET} in
|
||||
base-serv)
|
||||
@@ -405,20 +418,17 @@ case ${BUILD_TARGET} in
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
show_images_info() {
|
||||
# 查看镜像信息
|
||||
log_info "Docker镜像列表:"
|
||||
docker images | grep -E "school-news-" | head -15
|
||||
echo ""
|
||||
}
|
||||
|
||||
# 保存镜像
|
||||
if [ "${DO_SAVE}" = true ]; then
|
||||
save_images
|
||||
fi
|
||||
|
||||
# ================================================
|
||||
print_summary() {
|
||||
# 构建完成
|
||||
# ================================================
|
||||
echo "=========================================="
|
||||
log_info "✅ 构建完成!"
|
||||
echo "=========================================="
|
||||
@@ -426,3 +436,21 @@ log_info "构建目标: ${BUILD_TARGET}"
|
||||
log_info "构建版本: ${IMAGE_VERSION}"
|
||||
log_info "输出目录: ${BUILD_OUTPUT}"
|
||||
echo "=========================================="
|
||||
}
|
||||
|
||||
main() {
|
||||
git_update_if_needed
|
||||
run_compile
|
||||
run_build_images
|
||||
show_images_info
|
||||
|
||||
# 保存镜像(可选)
|
||||
if [ "${DO_SAVE}" = true ]; then
|
||||
save_images
|
||||
fi
|
||||
|
||||
print_summary
|
||||
}
|
||||
|
||||
main
|
||||
|
||||
|
||||
@@ -33,6 +33,8 @@ COPY schoolNewsCrawler/requirements.txt /tmp/requirements.txt
|
||||
RUN echo "========================================" && \
|
||||
echo "安装Python爬虫依赖到基础镜像" && \
|
||||
echo "========================================" && \
|
||||
# 配置pip使用国内镜像源(清华源)
|
||||
python3 -m pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple && \
|
||||
python3 -m pip --version && \
|
||||
echo "" && \
|
||||
# Python 3.12 引入了 PEP 668 规范,需要添加 --break-system-packages
|
||||
|
||||
@@ -9,8 +9,10 @@ FROM node:20-alpine
|
||||
ENV TZ=Asia/Shanghai \
|
||||
NODE_ENV=production
|
||||
|
||||
# 安装基础工具
|
||||
RUN apk add --no-cache tzdata bash curl && \
|
||||
# 配置国内镜像源并安装基础工具
|
||||
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g' /etc/apk/repositories && \
|
||||
apk update && \
|
||||
apk add --no-cache tzdata bash curl && \
|
||||
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
|
||||
echo "Asia/Shanghai" > /etc/timezone
|
||||
|
||||
@@ -24,7 +26,8 @@ RUN mkdir -p /app/dist /app/config /app/logs
|
||||
COPY schoolNewsWeb/package*.json ./
|
||||
|
||||
# 安装生产依赖(包括vite用于preview)
|
||||
RUN npm ci --only=production && \
|
||||
RUN npm config set registry https://registry.npmmirror.com && \
|
||||
npm ci --only=production && \
|
||||
npm install -g vite
|
||||
|
||||
# 从主机复制已构建的dist目录
|
||||
|
||||
Reference in New Issue
Block a user