原創(chuàng)文章,歡迎轉(zhuǎn)載。轉(zhuǎn)載請(qǐng)注明:轉(zhuǎn)載自IT人故事會(huì),謝謝!
原文鏈接地址:『中級(jí)篇』docker之CI/CD持續(xù)集成—真實(shí)JAVA-Maven項(xiàng)目的CI演示(73)
上次主要說(shuō)了在githubCI的服務(wù)器,并且也演示了github的runner執(zhí)行CICD,這次通過(guò)真實(shí)的JAVA-Maven項(xiàng)目來(lái)演示下CICD。項(xiàng)目通過(guò)gitlab和gitlabCI進(jìn)行CICD。
源碼地址:https://github.com/limingios/gitlabci-maven
源碼:https://github.com/limingios/docker/tree/master/No.11
隨便找一個(gè)開(kāi)源的JAVA-Maven的在github項(xiàng)目。添加到gitlab上。
copy到gitlab上
-
new project
- Git repository URL
- 點(diǎn)擊create project
runner管理新的gitlabci-maven
maven的環(huán)境
sudo gitlab-ci-multi-runner register
新建github-ci 文件
# These are the default stages. You don't need to explicitly define them. But you could define any stages you need.
stages:
- build
- test
- deploy
# This is the name of the job. You can choose it freely.
maven_build:
# A job is always executed within a stage. If no stage is set, it defaults to 'test'
stage: test
# Since we require Maven for this job, we can restrict the job to runners with a certain tag. Of course, we need to configure a runner with the tag maven with a maven installation
tags:
- maven
# Here you can execute arbitrate terminal commands.
# If any of the commands returns a non zero exit code the job fails
script:
- echo "Building project with maven"
- mvn verify
開(kāi)始CI操作
修改.gitlab-ci.yml 就開(kāi)啟了自動(dòng)構(gòu)建模式。
- 報(bào)錯(cuò)了。 跟python當(dāng)初構(gòu)建的時(shí)候一樣。
Running with gitlab-ci-multi-runner 9.5.1 (96b34cc)
on maven (e6c8a28d)
Using Docker executor with image maven:latest ...
Using docker image sha256:c4ef2f017e30bbabddf847a3f458985e55ccc24a2be7dbdf72dc032e7bece3e5 for predefined container...
Pulling docker image maven:latest ...
Using docker image maven:latest ID=sha256:1361ae58b0a463172267a0622430ad5f4f8108c4d4b7b1ae7d552e367cf92413 for build container...
Running on runner-e6c8a28d-project-3-concurrent-0 via gitlab-ci...
Cloning repository...
Cloning into '/builds/root/gitlabci-maven'...
fatal: unable to access 'http://gitlab-ci-token:xxxxxxxxxxxxxxxxxxxx@gitlab.example.com/root/gitlabci-maven.git/': Couldn't resolve host 'gitlab.example.com'
ERROR: Job failed: exit code 1
Runner啟動(dòng)的docker容器里無(wú)法訪問(wèn)到
gitlab.example.com
這個(gè)地址(能訪問(wèn)到才怪)。這一般是由于我們的測(cè)試環(huán)境沒(méi)有使用域名導(dǎo)致的,gitlab論壇里也不少人討論這個(gè)問(wèn)題,如果你是在部署正式的gitlab環(huán)境,那你自然會(huì)有一個(gè)域名來(lái)使用。不過(guò)我這里只是搭建測(cè)試環(huán)境,所以我使用了一種投機(jī)的方法:
修改Runner的/etc/gitlab-runner/config.toml
文件,在其中的[runner.docker]
下增加:
sudo vi /etc/gitlab-runner/config.toml
成功了 重新Retry
6666 美滋滋,當(dāng)初懟了個(gè)python現(xiàn)在java遇到這個(gè)問(wèn)題知道咋解決了。
用的不是阿里云,可能比較慢,不過(guò)是演示,之后想想辦法直接在腳本里面配置下私有庫(kù)的地址。
PS:這次主要給大家簡(jiǎn)單的介紹下CI,還沒(méi)設(shè)計(jì)到CD。下次吧!
往期精彩
- docker導(dǎo)學(xué)(一)
- 容器的技術(shù)概述(二)
- docker的魅力初體驗(yàn)-5分鐘安裝wordpress不走彎路(三)
- docker官網(wǎng)介紹(四)
- 如何在mac上安裝docker(五)
- 如何在window上安裝docker(六)
- 如何在mac上通過(guò)vagrant安裝虛擬機(jī)(七)
- 如何在window上通過(guò)vagrant安裝虛擬機(jī)(八)
- docker-Machine的本地使用(九)
- docker-Machine的本地使用(十)
- 在linux/mac下通過(guò)Docker-Machine在阿里云上的使用(11)
- docker架構(gòu)和底層技術(shù)(12)
- docker Image概述(13)
- 手動(dòng)建立一個(gè)base Image(14)
- 什么是Container(15)
- 構(gòu)建自己的Docker鏡像(16)
- Dockerfile詳解(17)
- 鏡像的發(fā)布(18)
- Dockerfile實(shí)戰(zhàn)(19)
- 容器的操作(20)
- Dockerfile實(shí)戰(zhàn)CMD和ENTRTYPOINT的配合(21)
- 容器的資源限制(22)
- docker網(wǎng)絡(luò)(23)
- docker學(xué)習(xí)必會(huì)網(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實(shí)現(xiàn)多機(jī)的容器通信(31)
- docker的數(shù)據(jù)持久化存儲(chǔ)和數(shù)據(jù)共享(32)
- windows下vagrant 通過(guò)SecureCRT連接centos7(33)
- 數(shù)據(jù)持久化之Data Volume(34)
- 數(shù)據(jù)持久化之bind Mounting(35)
- docker 使用bind Mounting實(shí)戰(zhàn)(36)
- docker容器安裝wordpress(37)
- docker Compose到底是什么(38)
- Docker Compose的安裝和基本使用(39)
- Docker 水平擴(kuò)展和負(fù)載均衡(40)
- Docker compose 部署一個(gè)復(fù)雜的應(yīng)用(41)
- 容器編排Docker Swarm介紹(42)
- docker-swarm創(chuàng)建一個(gè)多節(jié)點(diǎn)集群(43)
- play with docker 的使用(44)
- docker-swarm中的Service創(chuàng)建維護(hù)和水平擴(kuò)展(45)
- 在docker-swarm集群里通過(guò)serivce部署wordpress(46)
- 集群服務(wù)間通信之RoutingMesh(47)
- RoutingMesh之Ingress負(fù)載均衡(48)
- Docker-Stack部署wordpress(49)
- Docker-Stack部署投票應(yīng)用(50)
- Docker-Secret管理和使用(51)
- Docker service更新(52)
- Docker的收費(fèi)模式(53)
- Docker-cloud介紹(54)
- Docker Cloud自動(dòng)構(gòu)建 Docker image(55)
- Docker企業(yè)版的在線免費(fèi)體驗(yàn)(56)
- docker企業(yè)版本地安裝之UCP(57)
- docker體驗(yàn)阿里云的容器服務(wù)(58)
- 阿里云安裝Docker企業(yè)版UCP和DTR(59)
- Kubenetes簡(jiǎn)介(60)
- Minikube快速搭建K8S單節(jié)點(diǎn)環(huán)境(61)
- K8S最小調(diào)度單位Pod(62)
- K8S橫向擴(kuò)展功能ReplicaSet和ReplicationController(63)
- k8s重要的Deployment(64)
- Vagrant在本地搭建多節(jié)點(diǎn)K8S集群(65)
- k8s基礎(chǔ)網(wǎng)絡(luò)Cluster Network(66)
- k8s的Service簡(jiǎn)介和演示(67)
- k8s的NodePort類(lèi)型Service以及Label的簡(jiǎn)單實(shí)用(68)
- CI/CD持續(xù)集成/持續(xù)部署(69)
- docker之CI/CD持續(xù)集成-gitlab安裝(70)
- docker之CI/CD持續(xù)集成—GitLab CI服務(wù)器(71)
- docker之CI/CD持續(xù)集成—真實(shí)Python項(xiàng)目的CI演示(72)