gitlab CICD

服务器私有化部署gitlab社区版

社区版包4g,需要服务器上有足够的空间,部署私有化gitlab,配置端口,运行gitlab

安装gitRunner

Runner是CI/CD的执行者,运行你写的cicd文件,选择shell脚本,然后写yam文件,runner就会运行

  • 注册Runner,将runner与gitlab建立连接
  • runner有3种类型,共享(shared)Runner,组(group)Runner,项目(project)Runner
  • 代码提交或者合并的时候触发流水线,gitlab ci就会放进队列,找合适的runner来执行ci
  • 运行并反馈给gitlab

构建ci文件

skip ci\] 提交信息这样写,可以跳过执行流水线

配置流水线

  1. build
  2. test
  3. deploy
  4. 构建可以写一套,使用only来判断,只有某些分支才触发
  5. 认证服务器可以写成通用的(优化手段)
yml 复制代码
# 工作流规则:只有push操作触发
workflow:
  rules:
    - if: '$CI_PIPELINE_SOURCE == "push"'

# 定义阶段
stages:
  - build        # 构建阶段
  - deploy_test  # 测试环境部署
  - deploy_prod  # 生产环境部署

# 使用Node镜像
image: node:18

# 缓存node_modules加速构建
cache:
  paths:
    - node_modules/

# ==================== SSH密钥配置基座 ====================
.ssh_config:
  before_script:
    # 安装openssh-client(如果镜像没有)
    - apt-get update && apt-get install -y openssh-client
    # 创建SSH目录
    - mkdir -p ~/.ssh
    - chmod 700 ~/.ssh
    # 写入私钥(从GitLab变量读取)
    - echo "$SSH_PRIVATE_KEY" | tr -d '\r' > ~/.ssh/id_rsa
    - chmod 600 ~/.ssh/id_rsa
    # 添加服务器到known_hosts
    - ssh-keyscan -H $SSH_HOST >> ~/.ssh/known_hosts

# ==================== 构建作业 ====================
build_job:
  stage: build
  only:
    - test
    - master
  script:
    - echo "📦 开始安装依赖..."
    - npm ci
    
    - echo "🔨 开始构建项目..."
    - npm run build
    
    - echo "✅ 构建完成"
  artifacts:
    paths:
      - dist/
    expire_in: 1 hour

# ==================== 测试环境部署 ====================
deploy_test:
  extends: .ssh_config
  stage: deploy_test
  only:
    - test
  needs: ["build_job"]
  variables:
    SSH_HOST: $TEST_SSH_HOST
    SSH_USER: $TEST_SSH_USER
    DEPLOY_PATH: $TEST_DEPLOY_PATH
  script:
    - echo "🚀 开始部署到测试环境 ($SSH_HOST)..."
    
    # 清理目标目录
    - ssh $SSH_USER@$SSH_HOST "rm -rf $DEPLOY_PATH/*"
    
    # 复制dist文件到服务器
    - scp -r dist/* $SSH_USER@$SSH_HOST:$DEPLOY_PATH/
    
    - echo "✅ 测试环境部署完成!"

# ==================== 生产环境部署 ====================
deploy_prod:
  extends: .ssh_config
  stage: deploy_prod
  only:
    - master
  needs: ["build_job"]
  variables:
    SSH_HOST: $PROD_SSH_HOST
    SSH_USER: $PROD_SSH_USER
    DEPLOY_PATH: $PROD_DEPLOY_PATH
  script:
    - echo "🚀 开始部署到生产环境 ($SSH_HOST)..."
    
    # 备份当前版本
    - ssh $SSH_USER@$SSH_HOST "cp -r $DEPLOY_PATH ${DEPLOY_PATH}_backup_$(date +%Y%m%d_%H%M%S) || true"
    
    # 部署新版本
    - ssh $SSH_USER@$SSH_HOST "rm -rf $DEPLOY_PATH/*"
    - scp -r dist/* $SSH_USER@$SSH_HOST:$DEPLOY_PATH/
    
    # 如果是前端项目,可能需要reload nginx
    - ssh $SSH_USER@$SSH_HOST "sudo nginx -s reload || true"
    
    - echo "✅ 生产环境部署完成!"
相关推荐
前端摸鱼匠24 分钟前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker1 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
donecoding2 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马2 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren2 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川2 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo3 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技3 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE4 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript