『中级篇』docker之CI/CD持续集成——GitLab CI服务器(71)

如何搭建一个gitlab ci服务器,首先解释下为什么选择了gitlab ci没有选择jeakins
1.个人原因,jeakins 网上到处都是资料,怼gitlab ci更加熟悉。
2.gitlab和gitlab之前集成非常好的,这是不用质疑的。
3. 介绍下gitlab ci,不弱于jeakins,很多方面比jeakins对gitlab集成更强大。

创建虚拟机

  • vagrant文件的配置

# -*- mode: ruby -*-
# vi: set ft=ruby :

Vagrant.require_version ">= 1.6.0"

boxes = [
    {
        :name => "gitlab-ci",
        :mem => "4096",
        :cpu => "2"
    }
]

Vagrant.configure(2) do |config|

  config.vm.box = "centos/7"
  boxes.each do |opts|
    config.vm.define opts[:name] do |config|
      config.vm.hostname = opts[:name]
      config.vm.provider "vmware_fusion" do |v|
        v.vmx["memsize"] = opts[:mem]
        v.vmx["numvcpus"] = opts[:cpu]
      end
      config.vm.provider "virtualbox" do |v|
        v.customize ["modifyvm", :id, "--memory", opts[:mem]]
        v.customize ["modifyvm", :id, "--cpus", opts[:cpu]]
      end
      config.vm.network :private_network, type: "dhcp"
    end
  end
  config.vm.provision "shell", privileged: true, path: "./setup.sh"
end

  • setup.sh的配置
#/bin/sh

sudo yum install -y yum upgrade
sudo yum install -y net-tools
sudo yum install -y curl policycoreutils openssh-server openssh-clients
sudo systemctl enable sshd
sudo systemctl start sshd
sudo yum install -y postfix
sudo systemctl  enable postfix
sudo systemctl start postfix
sudo firewall-cmd --permanent --add-service=http
sudo systemctl reload firewalld

sudo curl -sSL https://get.docker.com/ | sh

执行命令创建

#源码No.11的gitlab-ci目录
vagrant up

更改安装源

新建 gitlab-ci-multi-runner.repo

sudo touch /etc/yum.repos.d/gitlab-ci-multi-runner.repo
sudo vi /etc/yum.repos.d/gitlab-ci-multi-runner.repo

将以下内容写入文件

[gitlab-ci-multi-runner]
name=gitlab-ci-multi-runner
baseurl=http://mirrors.tuna.tsinghua.edu.cn/gitlab-ci-multi-runner/yum/el7
repo_gpgcheck=0
gpgcheck=0
enabled=1
gpgkey=https://packages.gitlab.com/gpg.key

执行

sudo yum makecache
sudo yum install gitlab-ci-multi-runner

查询运行状态

 sudo gitlab-ci-multi-runner status

设置docker权限
为了能让gitlab-runner能正确的执行docker的命令,需要把gitlab-runner添加到docker group里,然后重启docker 和 gitlab-runner

sudo usermod -aG docker gitlab-runner
sudo service docker restart
sudo gitlab-ci-multi-runner restart 

gitlab-ci注册

  • 输入Gitlab CI地址
http://172.28.128.3/
  • 输入项目CI token
    >登录gitlab,选择项目,Setting,CICD,选择Runners。

i_qDxLL_yQTzMuSR1-6J
  • 输入 Runner 描述
#自己起个名字方便区别
test1
  • 输入 Runner 标签,可以多个,用逗号隔开
#自己起个标签方便区别
test1
  • 是否不需要每次tag后才打包(不,每次都要tag才会自动打包)。
#直接回车
  • 是否runner锁定在一个工程下(不)。
#直接回车
  • 输入 Runner 执行的语言
shell

gitlab-ci如何使用

  • 根目录添加.gitlab-ci.yml
stages:
  - test
  - build
  - deploy

job1:
  stage: test
  tags:
    - test1
  script:
    - echo "个人网站:idig8.com"
    - echo "个人公众号:编程坑太多"
    - echo "--------job1----------"
job2:
  stage: build
  tags:
    - test1
  script:
    - echo "个人网站:idig8.com"
    - echo "个人公众号:编程坑太多"
    - echo "--------job2----------"
job3:
  stage: deploy
  tags:
    - test1
  script:
    - echo "个人网站:idig8.com"
    - echo "个人公众号:编程坑太多"
    - echo "--------job3----------"
  • 查看运行结果
    >CICD-Pipelines

查看失败原因

#原来是域名的问题,开始修改。
Running with gitlab-ci-multi-runner 9.5.1 (96b34cc)  on gitlab-ci (4d12d67f)
Using Shell executor...Running on gitlab-ci...
Cloning repository...Cloning into '/home/gitlab-runner/builds/4d12d67f/0/root/test1'...
fatal: unable to access 'http://gitlab-ci-token:xxxxxxxxxxxxxxxxxxxx@gitlab.example.com/root/test1.git/': 
Could not resolve host: gitlab.example.com; Unknown errorERROR: Job failed: exit status 1
  • 进入gitlab-ci主机
    >修改hosts文件里面添加gitlab.example.com对应的ip。
sudo vi /etc/hosts 
# 添加 172.28.128.3 gitlab.example.com


重新ci

  • job1,job2,job3的结果
    >passed 就是已经结束了,运行成功了!必须是顺序执行,如果job1成功才执行job2,然后job3。

PS:整个这个功能是否给你一个很大的想象空间,任何的软件的项目,可以通过ci-Pipelines方式,来定义自己的Pipelines,在测试,部署。很大很的发挥空间。都可以通过自定yml文件来实现。

>>原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!
>>原文链接地址:『中级篇』docker之CI/CD持续集成——GitLab CI服务器(71)
上一篇: 下一篇:

发表评论

电子邮件地址不会被公开。 必填项已用*标注