本文共 3625 字,大约阅读时间需要 12 分钟。
原创文章,欢迎转载。转载请注明:转载自,谢谢!
原文链接地址:如何搭建一个gitlab ci服务器,首先解释下为什么选择了gitlab ci没有选择jeakins
1.个人原因,jeakins 网上到处都是资料,怼gitlab ci更加熟悉。2.gitlab和gitlab之前集成非常好的,这是不用质疑的。
- 介绍下gitlab ci,不弱于jeakins,很多方面比jeakins对gitlab集成更强大。源码:
# -*- 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
#/bin/sh
sudo yum install -y yum upgrade
sudo yum install -y net-toolssudo yum install -y curl policycoreutils openssh-server openssh-clientssudo systemctl enable sshdsudo systemctl start sshdsudo yum install -y postfixsudo systemctl enable postfixsudo systemctl start postfixsudo firewall-cmd --permanent --add-service=httpsudo systemctl reload firewalldsudo curl -sSL | sh
### 执行命令创建``` cmd#源码No.11的gitlab-ci目录vagrant up
新建 gitlab-ci-multi-runner.repo
sudo touch /etc/yum.repos.d/gitlab-ci-multi-runner.reposudo vi /etc/yum.repos.d/gitlab-ci-multi-runner.repo
将以下内容写入文件
[gitlab-ci-multi-runner]name=gitlab-ci-multi-runnerbaseurl=http://mirrors.tuna.tsinghua.edu.cn/gitlab-ci-multi-runner/yum/el7repo_gpgcheck=0gpgcheck=0enabled=1gpgkey=https://packages.gitlab.com/gpg.key
执行
sudo yum makecachesudo 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-runnersudo service docker restartsudo gitlab-ci-multi-runner restart
http://172.28.128.3/
登录gitlab,选择项目,Setting,CICD,选择Runners。
i_qDxLL_yQTzMuSR1-6J
#自己起个名字方便区别test1
#自己起个标签方便区别test1
是否不需要每次tag后才打包(不,每次都要tag才会自动打包)。
#直接回车
#直接回车
shell
stages: - test - build - deployjob1: 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
修改hosts文件里面添加gitlab.example.com对应的ip。
sudo vi /etc/hosts # 添加 172.28.128.3 gitlab.example.com
passed 就是已经结束了,运行成功了!必须是顺序执行,如果job1成功才执行job2,然后job3。
PS:整个这个功能是否给你一个很大的想象空间,任何的软件的项目,可以通过ci-Pipelines方式,来定义自己的Pipelines,在测试,部署。很大很的发挥空间。都可以通过自定yml文件来实现。
转载于:https://blog.51cto.com/12040702/2299671