CI/CD 全流程全解

🚀 CI/CD 全流程全解

一篇适合设备端开发者、嵌入式工程师、新手工程师的保姆级教程,涵盖从 GitLab CI/CD 搭建到边缘设备部署。


🧠 目录

  1. [CI/CD 简介](#CI/CD 简介)
  2. 环境准备
  3. [创建 .gitlab-ci.yml](#创建 .gitlab-ci.yml)
  4. 自定义编译脚本
  5. [部署配置 SSH 密钥](#部署配置 SSH 密钥)
  6. 流程示意图
  7. 调试技巧
  8. 实际应用场景

CI/CD 简介

缩写 全称 作用
CI Continuous Integration 自动编译、测试
CD Continuous Deployment 自动部署、上线

环境准备

✅ 安装 GitLab Runner

bash 复制代码
sudo apt install gitlab-runner
sudo gitlab-runner register

注册信息填写示例:

复制代码
GitLab URL: https://gitlab.com
Token: <项目Token>
描述: edge-runner
执行器: shell

创建 .gitlab-ci.yml

在项目根目录新建:

yaml 复制代码
stages:
  - build
  - deploy

variables:
  PROJECT_DIR: "/build/project"

build:
  stage: build
  script:
    - echo "🔧 开始编译..."
    - mkdir -p $PROJECT_DIR
    - cp -r * $PROJECT_DIR
    - cd $PROJECT_DIR
    - bash scripts/build_rk3588.sh
  artifacts:
    paths:
      - $PROJECT_DIR/output/

deploy:
  stage: deploy
  script:
    - echo "🚀 开始部署..."
    - scp $PROJECT_DIR/output/* root@192.168.1.100:/opt/heahu/
    - ssh root@192.168.1.100 'systemctl restart heahu.service'

自定义编译脚本

scripts/build_rk3588.sh

bash 复制代码
#!/bin/bash
export TOOLCHAIN=/opt/toolchains/rk3588
export PATH=$TOOLCHAIN/bin:$PATH

mkdir -p output
arm-linux-gnueabihf-g++ -o output/main core/main.cpp
cp configs/*.yaml output/

部署配置 SSH 密钥

bash 复制代码
ssh-keygen -t rsa -f deploy_key

将公钥添加到设备 ~/.ssh/authorized_keys

私钥添加到 GitLab 的变量:

变量名
SSH_PRIVATE_KEY deploy_key 内容

.gitlab-ci.yml 添加:

yaml 复制代码
before_script:
  - 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client -y )'
  - eval $(ssh-agent -s)
  - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
  - mkdir -p ~/.ssh
  - chmod 700 ~/.ssh
  - ssh-keyscan 192.168.1.100 >> ~/.ssh/known_hosts

流程示意图

plaintext 复制代码
GitLab 提交代码
      ↓
CI Runner 编译构建
      ↓
打包产物
      ↓
部署到设备
      ↓
自动重启服务

调试技巧

  • GitLab -> CI/CD -> Pipelines -> 查看日志
  • 构建失败时添加 echo 输出诊断信息
  • 确保 Runner 有权限连接设备

实际应用场景

场景 示例
模型更新 提交新 .rknn 自动替换部署
OTA 升级 提交代码后自动部署
一键测试 本地提交触发部署设备

如果你还需要 VSCode + GitLab 使用教程、边缘设备系统初始化脚本、部署模型自动更新流程等,欢迎关注后续内容。

相关推荐
前端摸鱼匠18 小时前
YOLOv8 环境配置全攻略:Python、PyTorch 与 CUDA 的和谐共生
人工智能·pytorch·python·yolo·目标检测
WangYaolove131418 小时前
基于python的在线水果销售系统(源码+文档)
python·mysql·django·毕业设计·源码
AALoveTouch18 小时前
大麦网协议分析
javascript·python
池央19 小时前
CANN oam-tools 诊断体系深度解析:自动化信息采集、AI Core 异常解析与 CI/CD 流水线集成策略
人工智能·ci/cd·自动化
ZH154558913119 小时前
Flutter for OpenHarmony Python学习助手实战:自动化脚本开发的实现
python·学习·flutter
xcLeigh19 小时前
Python入门:Python3 requests模块全面学习教程
开发语言·python·学习·模块·python3·requests
xcLeigh19 小时前
Python入门:Python3 statistics模块全面学习教程
开发语言·python·学习·模块·python3·statistics
胖虎119 小时前
Git 一个本地仓库同时推送到两个远程仓库(详细教程)
git·多远程仓库·双远程仓库·git双远程·git备份
YongCheng_Liang19 小时前
从零开始学 Python:自动化 / 运维开发实战(核心库 + 3 大实战场景)
python·自动化·运维开发
鸽芷咕20 小时前
为什么越来越多开发者转向 CANN 仓库中的 Python 自动化方案?
python·microsoft·自动化·cann