- Gitlab-CI使用及.gitlab-ci.yml配置入门一篇
- 『中级篇』docker之CI/CD持续集成—GitLab CI服
- 『中级篇』docker之CI/CD持续集成-CD演示(74)
- 『中级篇』docker之CI/CD持续集成-整个流程串联(75)
- 『中级篇』docker之CI/CD持续集成—真实Python项目
- 『中级篇』docker之CI/CD持续集成—真实JAVA-Mav
- 『中级篇』docker之CI/CD持续集成-gitlab安装(7
- 『中级篇』docker之CI/CD持续集成-项目生成镜像(76)
- 『中级篇』docker之CI/CD持续集成-(终结篇)(77)
- gitlab CI + jenkins 实践
原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!
原文链接地址:『中级篇』docker之CI/CD持续集成——GitLab CI服务器(71)
如何搭建一个gitlab ci服务器,首先解释下为什么选择了gitlab ci没有选择jeakins
1.个人原因,jeakins 网上到处都是资料,怼gitlab ci更加熟悉。
2.gitlab和gitlab之前集成非常好的,这是不用质疑的。
- 介绍下gitlab ci,不弱于jeakins,很多方面比jeakins对gitlab集成更强大。
源码:https://github.com/limingios/docker/tree/master/No.11
创建虚拟机
- 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文件来实现。
往期精彩
- docker导学(一)
- 容器的技术概述(二)
- docker的魅力初体验-5分钟安装wordpress不走弯路(三)
- docker官网介绍(四)
- 如何在mac上安装docker(五)
- 如何在window上安装docker(六)
- 如何在mac上通过vagrant安装虚拟机(七)
- 如何在window上通过vagrant安装虚拟机(八)
- docker-Machine的本地使用(九)
- docker-Machine的本地使用(十)
- 在linux/mac下通过Docker-Machine在阿里云上的使用(11)
- docker架构和底层技术(12)
- docker Image概述(13)
- 手动建立一个base Image(14)
- 什么是Container(15)
- 构建自己的Docker镜像(16)
- Dockerfile详解(17)
- 镜像的发布(18)
- Dockerfile实战(19)
- 容器的操作(20)
- Dockerfile实战CMD和ENTRTYPOINT的配合(21)
- 容器的资源限制(22)
- docker网络(23)
- docker学习必会网络基础(24)
- Linux网络命名空间(25)
- Docker Bridge详解(26)
- 容器之间的Link(27)
- 容器的端口映射(28)
- 容器网络之host和none(29)
- 多容器复杂应用的部署(30)
- overlay网络和etcd实现多机的容器通信(31)
- docker的数据持久化存储和数据共享(32)
- windows下vagrant 通过SecureCRT连接centos7(33)
- 数据持久化之Data Volume(34)
- 数据持久化之bind Mounting(35)
- docker 使用bind Mounting实战(36)
- docker容器安装wordpress(37)
- docker Compose到底是什么(38)
- Docker Compose的安装和基本使用(39)
- Docker 水平扩展和负载均衡(40)
- Docker compose 部署一个复杂的应用(41)
- 容器编排Docker Swarm介绍(42)
- docker-swarm创建一个多节点集群(43)
- play with docker 的使用(44)
- docker-swarm中的Service创建维护和水平扩展(45)
- 在docker-swarm集群里通过serivce部署wordpress(46)
- 集群服务间通信之RoutingMesh(47)
- RoutingMesh之Ingress负载均衡(48)
- Docker-Stack部署wordpress(49)
- Docker-Stack部署投票应用(50)
- Docker-Secret管理和使用(51)
- Docker service更新(52)
- Docker的收费模式(53)
- Docker-cloud介绍(54)
- Docker Cloud自动构建 Docker image(55)
- Docker企业版的在线免费体验(56)
- docker企业版本地安装之UCP(57)
- docker体验阿里云的容器服务(58)
- 阿里云安装Docker企业版UCP和DTR(59)
- Kubenetes简介(60)
- Minikube快速搭建K8S单节点环境(61)
- K8S最小调度单位Pod(62)
- K8S横向扩展功能ReplicaSet和ReplicationController(63)
- k8s重要的Deployment(64)
- Vagrant在本地搭建多节点K8S集群(65)
- k8s基础网络Cluster Network(66)
- k8s的Service简介和演示(67)
- k8s的NodePort类型Service以及Label的简单实用(68)
- CI/CD持续集成/持续部署(69)
- docker之CI/CD持续集成-gitlab安装(70)
网友评论