您好,登錄后才能下訂單哦!
這篇“Gitlab-runner+Docker怎么實現自動部署SpringBoot項目”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Gitlab-runner+Docker怎么實現自動部署SpringBoot項目”文章吧。
以下服務器的操作系統均為Centos7
服務器A:Gitlab
服務器B:GitlabRunner、Docker、docker-compose、Java1.8、maven3.6.3、git
ps:這里可以把服務器B的GitlabRunner、Java1.8、maven3.6.3、git單獨提出來,獨立部署,需要java的原因是maven,maven用于打包。
應用服務器B就只需要docker和docker-compose就可以了,為了演示方便,這里放一起的。
相關服務搭建教程參照官方文檔或其他第三方靠譜博客教程!
Gitlab:14.9
GitlabRunner:14.10.0
docker:20.10.14
docker-compose:1.29.2
Git:2.31.1 ,事先檢查下Git是否最新版本,否則后面會出錯。
我們的主要流程就是通過Gitlab管理代碼,然后利用Gitlab自帶的Gitlab CI/CD功能與GitlabRunner進行注冊綁定。
綁定成功后,每提交一次代碼,都可以觸發GitlabRunner,從而執行相應的腳本程序實現自動部署。
For Debian/Ubuntu/Mint
curl -L https://packages.gitlab.com/install/repositories/runner/gitlab-runner/script.deb.sh | sudo bash
For RHEL/CentOS/Fedora
curl -L https://packages.gitlab.com/install/repositories/runner/gitlab-runner/script.rpm.sh | sudo bash
For Debian/Ubuntu/Mint
sudo apt-get install gitlab-ci-multi-runner
For RHEL/CentOS/Fedora
sudo yum -y install gitlab-ci-multi-runner
1.打開Gitlab需要自動部署的倉庫,選擇Setting-》CI / CD -》Runners。
2.如下圖,可以看到最關鍵的兩個信息,這倆待會GitlabRunner注冊的時候會用到.
3.GitlabRunner注冊:
基本命令:
注冊:gitlab-runner register
查看已注冊Runner:gitlab-runner list
取消所有注冊:gitlab-runner unregister --all-runners
回到服務器B,執行命令gitlab-runner register
注冊流程詳解:
Enter the GitLab instance URL (for example, https://gitlab.com/):
輸入gitlab的服務URL
Enter the registration token:
輸入令牌,參考上圖
Enter a description for the runner:
輸入Runner描述
Enter tags for the runner (comma-separated)
給這個gitlab-runner輸入一個標記,這個tag非常重要,在后續的使用過程中需要使用這個tag來指定gitlab-runner(yml文件,job通過設置tags標簽選用指定的Runner)
Enter optional maintenance note for the runner:
輸入可選維護說明
Enter an executor: docker+machine, docker-ssh+machine, custom, docker-windows, docker-ssh, ssh, kubernetes, docker, parallels, shell, virtualbox:
回車結束,安裝gitlab-runner文件夾下會自動生成config.
回到gitlab后臺Runner設置處,刷新頁面就可以看到新增的一個Runner:
當提交代碼后,我們應該怎么用Shell腳本來控制構建和部署呢?Gitlab為我們提供好了一個模版,就是在倉庫根目錄下創建名為:.gitlab-ci.yml 文件
這里以一個springboot項目為例子,在原項目基礎上增加了3個文件(.gitlab-ci.yml 、Dockerfile 、docker-compose.yml),下面展示了文件的位置和內容,內容根據你的需求修改就行了,需要熟悉Dockerfile 和 docker-compose.yml的一些基礎文件結構及語法:
stages: - build - deploy_dev - clean # 打包鏡像 build: stage: build only: - dev script: - $MAVEN_HOME/bin/mvn clean package '-Dmaven.test.skip=true' - cp ./XXX/target/XXX.jar docker/ - cd docker - docker build -t dev/XXX:v1.0.0 . tags: - maven # 部署開發服務器 deploy_dev: stage: deploy_dev only: - dev script: - cd docker - docker-compose down - docker-compose up -d tags: - maven #清理虛懸鏡像 clean: stage: clean only: - dev script: - docker rmi $(docker images -q -f dangling=true) tags: - maven
在根目錄中創建Docker文件夾,
創建Dockerfile:
#FROM java:8 #java:8這個鏡像體積有643MB,打包鏡像后體積太大了,不建議使用 # openjdk:8-jre-alpine 體積最小,只有85MB FROM openjdk:8-jre-alpine # 以下2個RUN解決 java驗證碼接口報錯的問題, RUN echo -e "https://mirror.tuna.tsinghua.edu.cn/alpine/v3.4/main\n\ https://mirror.tuna.tsinghua.edu.cn/alpine/v3.4/community" > /etc/apk/repositories RUN apk --update add curl bash ttf-dejavu && \ rm -rf /var/cache/apk/* COPY . /opt/app WORKDIR /opt/app
創建docker-compose.yml :
version: '3.1' services: education-course: container_name: dev-XXX-server restart: always image: dev/XXX:v1.0.0 network_mode: "host" volumes: - /opt/XXX-server/logs:/XXX/logs command: java -jar -Xms1024m -Xmx1024m -Duser.timezone=GMT+08 xxx.jar --spring.profiles.active=dev
本地idea提交一次代碼到dev分支,可以到已經在跑了
點進去看,出現問題
這里提示我們的git版本太低了
當前git版本:
[root@localhost local]# git --version git version 1.8.3.1
升級最新版git后:
[root@localhost yum.repos.d]# git --version git version 2.24.4
回到gitlab后臺,這里手動再執行一次:
最新的一次已通過 passed:
查看日志的方法,進第一個build查看日志,獲取項目的路徑(大家有更好的方法可以告訴下我)
cd到 項目的docker目錄,使用
docker-compose logs -ft
測試接口:
問題1:自動化部署build報錯:
解決方法,執行命令:
sudo chmod 777 /var/run/docker.sock
問題2:docker apline temporary error (try again later) 錯誤
沒有dns導致的
在本機系統上創建daemon文件添加dns,然后重啟docker
vim /etc/docker/daemon.json { "dns": ["8.8.8.8"] } sudo service docker restart
以上就是關于“Gitlab-runner+Docker怎么實現自動部署SpringBoot項目”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。