云原生 | Docker + GitLab + GitLab Runner 自动化部署

云原生 | Docker + GitLab + GitLab Runner 自动化部署

CI/CD

CI/CD 是持续集成 (CI-Continuous Integration) 和持 续交付(Continuous Delivery) 或持续部署(CD-Continuous Deployment) 的组合实践。CI/CD 实践构成了现代 DevOps 操作的支柱。

持续集成主要包含以下步骤:

  • 自动化构建Continuous Build
  • 自动化测试Continuous Test, 验证软件功能
  • 自动化集成Continuous Intergration

GitLab

目前市面上实现自动化部署的开源方案一般有两个(JenkinsGitLab)。从可扩展性而言Jenkins是更好的选择,不过自由也意味着很多东西都需要自己配置

Gitlab 是开源的 devops 平台,集成了 Gitlab CI/CD 功能,GitLab作为代码仓库管理系统,提供了可视化界面、版本控制、代码审核等功能,而GitLab Runner则是CI/CD的执行器,负责执行GitLab中配置的任务,可以自动从GitLab上获取任务并执行

  • 开发者在commit代码或者提交merge request会自动触发CI/CD流程
  • 流程开始后,会主动读取项目根目录下的 .gitlab_ci.yml 文件,获取构建镜像,构建步骤,构建命令等,并运行一个 CI pipeline(一个pipeline通常分为三个阶段:build,test,deploy),即会执行一系列任务,如用eslint校验代码规范,单元测试等。
  • 根据.gitlab_ci.yml中配置的stage中的tags,选择对应的GitLab Runner,根据配置的image启动容器,并在该容器中执行stage中的构建命令

Gitlab CI/CDpipeline(流水线),stage(阶段),job(任务)之间的关系为:pipeline 包含了若干个 stagestage 包含了多个 jobjob 是流水线中最小的单位,这些任务是在 GitLab Runner 中运行。

GitLab还集成了sentry sdk,可通过连接sentry进行监控,还可以接入kubernets集群等

实践开始

GitLab环境安装配置

  1. docker拉取GitLab镜像,运行

    ## 拉取镜像
    sudo docker pull docker.io/gitlab/gitlab-ce
    
    ## 创建目录
    sudo mkdir -p /gitlab/data
    sudo mkdir -p /gitlab/logs
    sudo mkdir -p /gitlab/config
    
    ## 运行
    sudo docker run --detach \
        --publish 8443:443 --publish 8000:80 --publish 2222:22 \
        --name gitlab \
        --restart always \
        --volume /gitlab/config:/etc/gitlab \
        --volume /gitlab/logs:/var/log/gitlab \
        --volume /gitlab/data:/var/opt/gitlab \
        -log-driver=none \
        docker.io/gitlab/gitlab-ce:latest
    

    速度过于慢了😭, 已经配置好了镜像源

    image-20230513144344483

  2. 进入镜像容器内修改

修改external_urlexternal_url 'http://IP:8000' # IP填写GitLab部署的服务器的IP

修改ssh端口: gitlab_rails['gitlab_shell_ssh_port'] = 2222

修改nginx监听的端口nginx['listen_port'] = 80

  1. 在config下有一个文件存放了root用户的密码

    image-20230616014041752

  2. 修改root密码

  3. GitLab里面的模板创建个 项目

GitLab Runner环境安装配置

  1. docker拉取gitlab/gitlab-runner镜像,运行

    docker pull gitlab/gitlab-runner
    
    docker run -d --name gitlab-runner --restart always \
      -v /home/gitlab-runner/config:/etc/gitlab-runner \
      -v /var/run/docker.sock:/var/run/docker.sock \
      gitlab/gitlab-runner:latest
    

    创建一个项目

    image-20230616110855638

    image-20230616110906574

    拉取代码

    image-20230616111048887

    git clone http://192.168.253.128:8000/root/hello.git
    # 将中间的那一串改成ip
    

    上传一个 Go 文件

    package main
    
    import (
            "fmt"
            "net/http"
    )
    
    func indexHandler(w http.ResponseWriter, r *http.Request) {
            fmt.Fprintf(w, "hello CI/CD")
    }
    func main() {
            http.HandleFunc("/", indexHandler)
            fmt.Println("listening on http://localhost:8009")
            http.ListenAndServe(":8009", nil)
    }
    
    

    之后复制这里的 Registration token

    image-20230616104551003

    进入gitlab-runner容器中

    docker exec -it gitlab-runner /bin/bash
    

    开始注册 runner

    //进入容器后输入
    gitlab-ci-multi-runner register
    

    image-20230616105548731

    执行之后可以看到注册的 Runner

    image-20230616105617255

    自动化部署项目

    首先在仓库中添加文件:.gitlab-ci.yml,内容如下

    # ci demo 
    stages:          # List of stages for jobs, and their order of execution
      - build
      - test
      - deploy
    
    build-job:       # This job runs in the build stage, which runs first.
      stage: build
      script:
        - echo "Compiling the code..."
        - echo "Compile complete."
    
    test-job:   # This job also runs in the test stage.
      stage: test    # It can run at the same time as unit-test-job (in parallel).
      script:
        - echo "Linting code... This will take about 10 seconds."
        - sleep 10
        - echo "No lint issues found."
    
    deploy-job:      # This job runs in the deploy stage.
      stage: deploy  # It only runs when *both* jobs in the test stage complete successfully.
      environment: production
      script:
        - echo "Deploying application..."
        - echo "Application successfully deployed."
    

    提交到仓库,查看流水线可以看到

    image-20230616110016880

参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值