原創(chuàng)文章,歡迎轉(zhuǎn)載钥弯。轉(zhuǎn)載請注明:轉(zhuǎn)載自IT人故事會竟块,謝謝!
原文鏈接地址:『中級篇』docker之CI/CD持續(xù)集成——GitLab CI服務(wù)器(71)
如何搭建一個gitlab ci服務(wù)器耕突,首先解釋下為什么選擇了gitlab ci沒有選擇jeakins
1.個人原因笤成,jeakins 網(wǎng)上到處都是資料,懟gitlab ci更加熟悉有勾。
2.gitlab和gitlab之前集成非常好的疹启,這是不用質(zhì)疑的。
- 介紹下gitlab ci蔼卡,不弱于jeakins喊崖,很多方面比jeakins對gitlab集成更強大。
源碼:https://github.com/limingios/docker/tree/master/No.11
創(chuàng)建虛擬機
- 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
執(zhí)行命令創(chuàng)建
#源碼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
將以下內(nèi)容寫入文件
[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
執(zhí)行
sudo yum makecache
sudo yum install gitlab-ci-multi-runner
查詢運行狀態(tài)
sudo gitlab-ci-multi-runner status
設(shè)置docker權(quán)限
為了能讓gitlab-runner能正確的執(zhí)行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 描述
#自己起個名字方便區(qū)別
test1
- 輸入 Runner 標(biāo)簽廊宪,可以多個,用逗號隔開
#自己起個標(biāo)簽方便區(qū)別
test1
- 是否不需要每次tag后才打包(不女轿,每次都要tag才會自動打包)箭启。
#直接回車
- 是否runner鎖定在一個工程下(不)。
#直接回車
- 輸入 Runner 執(zhí)行的語言
shell
gitlab-ci如何使用
- 根目錄添加.gitlab-ci.yml
stages:
- test
- build
- deploy
job1:
stage: test
tags:
- test1
script:
- echo "個人網(wǎng)站:idig8.com"
- echo "個人公眾號:編程坑太多"
- echo "--------job1----------"
job2:
stage: build
tags:
- test1
script:
- echo "個人網(wǎng)站:idig8.com"
- echo "個人公眾號:編程坑太多"
- echo "--------job2----------"
job3:
stage: deploy
tags:
- test1
script:
- echo "個人網(wǎng)站:idig8.com"
- echo "個人公眾號:編程坑太多"
- echo "--------job3----------"
- 查看運行結(jié)果
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對應(yīng)的ip。
sudo vi /etc/hosts
# 添加 172.28.128.3 gitlab.example.com
重新ci
- job1北救,job2荐操,job3的結(jié)果
passed 就是已經(jīng)結(jié)束了,運行成功了珍策!必須是順序執(zhí)行托启,如果job1成功才執(zhí)行job2,然后job3攘宙。
PS:整個這個功能是否給你一個很大的想象空間屯耸,任何的軟件的項目,可以通過ci-Pipelines方式模聋,來定義自己的Pipelines肩民,在測試唠亚,部署链方。很大很的發(fā)揮空間。都可以通過自定yml文件來實現(xiàn)灶搜。
往期精彩
- docker導(dǎo)學(xué)(一)
- 容器的技術(shù)概述(二)
- docker的魅力初體驗-5分鐘安裝wordpress不走彎路(三)
- docker官網(wǎng)介紹(四)
- 如何在mac上安裝docker(五)
- 如何在window上安裝docker(六)
- 如何在mac上通過vagrant安裝虛擬機(七)
- 如何在window上通過vagrant安裝虛擬機(八)
- docker-Machine的本地使用(九)
- docker-Machine的本地使用(十)
- 在linux/mac下通過Docker-Machine在阿里云上的使用(11)
- docker架構(gòu)和底層技術(shù)(12)
- docker Image概述(13)
- 手動建立一個base Image(14)
- 什么是Container(15)
- 構(gòu)建自己的Docker鏡像(16)
- Dockerfile詳解(17)
- 鏡像的發(fā)布(18)
- Dockerfile實戰(zhàn)(19)
- 容器的操作(20)
- Dockerfile實戰(zhàn)CMD和ENTRTYPOINT的配合(21)
- 容器的資源限制(22)
- docker網(wǎng)絡(luò)(23)
- docker學(xué)習(xí)必會網(wǎng)絡(luò)基礎(chǔ)(24)
- Linux網(wǎng)絡(luò)命名空間(25)
- Docker Bridge詳解(26)
- 容器之間的Link(27)
- 容器的端口映射(28)
- 容器網(wǎng)絡(luò)之host和none(29)
- 多容器復(fù)雜應(yīng)用的部署(30)
- overlay網(wǎng)絡(luò)和etcd實現(xiàn)多機的容器通信(31)
- docker的數(shù)據(jù)持久化存儲和數(shù)據(jù)共享(32)
- windows下vagrant 通過SecureCRT連接centos7(33)
- 數(shù)據(jù)持久化之Data Volume(34)
- 數(shù)據(jù)持久化之bind Mounting(35)
- docker 使用bind Mounting實戰(zhàn)(36)
- docker容器安裝wordpress(37)
- docker Compose到底是什么(38)
- Docker Compose的安裝和基本使用(39)
- Docker 水平擴展和負載均衡(40)
- Docker compose 部署一個復(fù)雜的應(yīng)用(41)
- 容器編排Docker Swarm介紹(42)
- docker-swarm創(chuàng)建一個多節(jié)點集群(43)
- play with docker 的使用(44)
- docker-swarm中的Service創(chuàng)建維護和水平擴展(45)
- 在docker-swarm集群里通過serivce部署wordpress(46)
- 集群服務(wù)間通信之RoutingMesh(47)
- RoutingMesh之Ingress負載均衡(48)
- Docker-Stack部署wordpress(49)
- Docker-Stack部署投票應(yīng)用(50)
- Docker-Secret管理和使用(51)
- Docker service更新(52)
- Docker的收費模式(53)
- Docker-cloud介紹(54)
- Docker Cloud自動構(gòu)建 Docker image(55)
- Docker企業(yè)版的在線免費體驗(56)
- docker企業(yè)版本地安裝之UCP(57)
- docker體驗阿里云的容器服務(wù)(58)
- 阿里云安裝Docker企業(yè)版UCP和DTR(59)
- Kubenetes簡介(60)
- Minikube快速搭建K8S單節(jié)點環(huán)境(61)
- K8S最小調(diào)度單位Pod(62)
- K8S橫向擴展功能ReplicaSet和ReplicationController(63)
- k8s重要的Deployment(64)
- Vagrant在本地搭建多節(jié)點K8S集群(65)
- k8s基礎(chǔ)網(wǎng)絡(luò)Cluster Network(66)
- k8s的Service簡介和演示(67)
- k8s的NodePort類型Service以及Label的簡單實用(68)
- CI/CD持續(xù)集成/持續(xù)部署(69)
- docker之CI/CD持續(xù)集成-gitlab安裝(70)