Update Jenkinsfile

This commit is contained in:
木鱼和金鱼 2026-01-24 13:42:35 +08:00 committed by GitHub
parent 196c0b0837
commit d32b3895e6
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

100
Jenkinsfile vendored
View File

@ -74,59 +74,59 @@ pipeline {
} }
} }
stage('Deploy via SSH') { stage('Deploy via SSH') {
steps { steps {
withEnv([]) { withEnv([]) {
echo "通过 SSH 部署到宿主机: ${HOST_TARGET}" echo "通过 SSH 部署到宿主机: ${HOST_TARGET}"
sh ''' sh '''
# 1. 检查SSH密钥文件是否存在 # 1. 检查SSH密钥文件是否存在
if [ ! -f "${SSH_KEY_PATH}" ]; then if [ ! -f "${SSH_KEY_PATH}" ]; then
echo "❌ 错误: SSH密钥文件不存在: ${SSH_KEY_PATH}" echo "❌ 错误: SSH密钥文件不存在: ${SSH_KEY_PATH}"
exit 1 exit 1
fi
# 2. 设置密钥权限(确保只有所有者可读)
chmod 600 ${SSH_KEY_PATH}
# 3. 宿主机创建备份目录
ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "mkdir -p ${HOST_BACKUP}"
# 4. 宿主机备份原有部署目录(如有)
ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "
if [ -d '${HOST_TARGET}' ]; then
TIMESTAMP=$(date +%Y%m%d%H%M%S)
mv '${HOST_TARGET}' '${HOST_BACKUP}/backup_$TIMESTAMP'
fi fi
"
# 2. 设置密钥权限(确保只有所有者可读)
# 5. SCP传输构建产物到宿主机注意scp命令的-i参数位置 chmod 600 ${SSH_KEY_PATH}
scp -i ${SSH_KEY_PATH} -r -o StrictHostKeyChecking=no build-output/* ${HOST_USER}@${HOST_IP}:${HOST_TARGET}/
# 3. 宿主机创建备份目录
# 6. 宿主机修复目录权限 ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "mkdir -p ${HOST_BACKUP}"
ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "chmod -R 755 ${HOST_TARGET}"
# 4. 宿主机备份原有部署目录(如有)
# 7. 安装后端生产依赖 ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "
echo "安装后端生产依赖..." if [ -d '${HOST_TARGET}' ]; then
ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} " TIMESTAMP=$(date +%Y%m%d%H%M%S)
cd ${HOST_TARGET}/backend mv '${HOST_TARGET}' '${HOST_BACKUP}/backup_$TIMESTAMP'
npm install --production fi
" "
# 8. 配置目录权限 # 5. SCP传输构建产物到宿主机注意scp命令的-i参数位置
ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} " scp -i ${SSH_KEY_PATH} -r -o StrictHostKeyChecking=no build-output/* ${HOST_USER}@${HOST_IP}:${HOST_TARGET}/
chmod -R 755 ${HOST_TARGET}
if id -u www >/dev/null 2>&1; then # 6. 宿主机修复目录权限
chown -R www:www ${HOST_TARGET} ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "chmod -R 755 ${HOST_TARGET}"
fi
" # 7. 安装后端生产依赖
echo "安装后端生产依赖..."
echo "✅ 部署完成!" ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "
echo "前端访问地址: http://192.168.10.168/aistudy" cd ${HOST_TARGET}/backend
echo "后端服务目录: ${HOST_TARGET}/backend" npm install --production
''' "
# 8. 配置目录权限
ssh -i ${SSH_KEY_PATH} -o StrictHostKeyChecking=no ${HOST_USER}@${HOST_IP} "
chmod -R 755 ${HOST_TARGET}
if id -u www >/dev/null 2>&1; then
chown -R www:www ${HOST_TARGET}
fi
"
echo "✅ 部署完成!"
echo "前端访问地址: http://192.168.10.168/aistudy"
echo "后端服务目录: ${HOST_TARGET}/backend"
'''
}
} }
} }
}
post { post {
success { success {
echo '🎉 本地部署成功!' echo '🎉 本地部署成功!'