基于 gitee 的 CI/CD

基于 gitee 的 CI/CD 流程简介。

CI/CD 流程是指在软件开发过程中,通过自动化的方式实现代码的持续集成、持续部署和持续交付。

CI/CD 流程通常包括以下几个步骤:

  1. 代码提交:开发者将代码提交到代码仓库,如 Git、SVN 等。
  2. 代码构建:CI/CD 服务器接收到代码提交后,自动触发代码构建。代码构建通常包括编译、测试、打包等步骤。
  3. 代码测试:CI/CD 服务器执行代码测试,确保代码的质量和稳定性。(暂未实现:测试代码需要在服务器上运行)
  4. 代码部署:CI/CD 服务器将代码部署到测试环境或生产环境中。(暂未实现:接受部署的主机需要可以连接到公网)

创建代码仓库

  1. 在 gitee 中创建一个代码仓库, 如 "test_CI_CD"
  2. 上传demo code 到代码仓库
c++ 复制代码
#include <iostream>
#include <chrono>
#include <ctime>
#include <iomanip>

int main() {
    auto now = std::chrono::system_clock::now();
    
    // 将时间点转换为 time_t
    std::time_t now_time = std::chrono::system_clock::to_time_t(now);
    
    // 将 time_t 转换为本地时间
    std::tm* local_time = std::localtime(&now_time);
    
    // 打印当前时间
    std::cout << "Build time: " << std::put_time (local_time, "%Y-%m-%d %H:%M:%S") << std::endl;

    std::cout << "Hello, World!" << std::endl;
    std::cout << "Current version: V1.00.01" << std::endl;
    return 0;
}
  1. 创建 Makefile 文件
makefile 复制代码
# 定义编译器
CXX = g++

# 定义编译选项
CXXFLAGS = -std=c++11 -Wall

# 定义目标文件名
TARGET = myprogram

# 定义源文件
SRCS = main.cpp

# 定义目标文件和输出目录
OBJDIR = build
OBJS = $(addprefix $(OBJDIR)/, $(SRCS:.cpp=.o))

# 默认目标
all: $(TARGET)

# 创建输出目录
$(OBJDIR):
	mkdir -p $@

# 链接目标文件生成可执行文件
$(TARGET): $(OBJS)
	$(CXX) $(CXXFLAGS) -o $(TARGET) $(OBJS) -lstdc++

# 编译源文件生成目标文件
$(OBJDIR)/%.o: %.cpp | $(OBJDIR)
	$(CXX) $(CXXFLAGS) -c $< -o $@

# 清理生成的文件
clean:
	rm -rf $(OBJDIR) $(TARGET)

创建 CI/CD 流程

1. 流水线

Gitee提供了一个在线的流水线编辑器,可以通过它来创建流水线。

使用模版创建流水线后,会在您的代码库产生一次提交,根目录下生成.workflow文件夹,并分别产生MasterPipeline.yml、BranchPipeline.yml、PRPipeline.yml三个流水线描述文件。之后,您可以提交代码或发起 PR 感受 Gitee Go 带来的便捷啦!

2. 修改 MasterPipeline.yml 文件

现在选择 MasterPipeline.yml 文件,在master push时,自动执行编译和发布;修改为如下内容:

2.1 GCC构建

因demo code 中使用了c++,需要使用gcc编译。

在这一步中,主要修改的时构建命令:

makefile 复制代码
 g++ --version

 make

其他步骤,如上传制品,发布等,暂未修改。

3 最终生成的文件

3.1 文件布局

3.2 最终的 MasterPipeline.yml 文件

yml 复制代码
version: '1.0'
name: master-pipeline
displayName: MasterPipeline
triggers:
  trigger: auto
  push:
    branches:
      include:
        - master
stages:
  - name: compile
    displayName: 编译
    strategy: naturally
    trigger: auto
    steps:
      - step: build@gcc
        name: build_gcc
        displayName: GCC 构建
        gccVersion: '9.4'
        commands:
          - ' g++ --version'
          - ''
          - ' make'
        artifacts:
          - name: BUILD_ARTIFACT
            path:
              - myprogram
        caches: []
        notify: []
        strategy:
          retry: '0'
      - step: publish@general_artifacts
        name: publish_general_artifacts
        displayName: 上传制品
        dependArtifact: BUILD_ARTIFACT
        artifactName: output
        strategy: {}
        dependsOn: build_gcc
  - name: release
    displayName: 发布
    strategy: naturally
    trigger: auto
    steps:
      - step: publish@release_artifacts
        name: publish_release_artifacts
        displayName: 发布
        dependArtifact: output
        version: 1.0.0.0
        autoIncrement: true
        strategy: {}

验证

1. 查看构建历史

完成上述步骤后,在 gitee 中提交代码,即可看到流水线的运行结果。

2. 查看gcc构建过程

3. 查看制品

4. 下载制品并验证

Gitee 帮助中心

Gitee 帮助中心

相关推荐
好好学习 6665 小时前
gitlab-ci.yml文件详解
java·ci/cd·gitlab
带娃的IT创业者16 小时前
《Python实战进阶》No26: CI/CD 流水线:GitHub Actions 与 Jenkins 集成
python·ci/cd·github
A尘埃18 小时前
腾讯云数据万象服务CI(内容审核)
ci/cd·腾讯云
先知-旭日东升19 小时前
VSCode中操作gitee
ide·vscode·gitee
kuaile09061 天前
2025 年 DevOps 工具全景解析:赋能高效研发与智能运维
运维·gitee·团队开发·敏捷开发·devops·源代码管理
码农葫芦侠2 天前
GitLab CI/CD学习教程(第三章Pipeline)
学习·ci/cd·gitlab
Warren983 天前
十分钟学会Git
java·ide·笔记·git·gitee
滴答滴答嗒嗒滴4 天前
CI/CD 全流程全解
chrome·git·python·ci/cd·gitlab
Sirius Wu5 天前
CI/CD构建与注意事项
ci/cd
一袋米扛几楼985 天前
【Devops】DevOps and CI/CD Pipelines
运维·ci/cd·devops