本文首發於個人我的博客,Docker Gitlab CI 部署 Spring Boot 項目 ,歡迎訪問!html
目前在學習這一塊的內容,可是可能每一個人環境都不一樣,致使找不到一篇博客可以徹底操做下來沒有錯誤的,因此本身也寫一下,記錄一下整個搭建的過程。java
Docker 的安裝這裏就不贅述了,基本上幾行命令均可以了,不會的能夠搜一下其餘的博客。我本地使用的環境以下:linux
下面詳細講一下部署的過程。nginx
閱讀這篇博客的朋友關注點應該在 Gitlab CI 上,所以假設你們對 Docker 和 Gitlab 自己是有必定的瞭解,掌握基本使用的。git
對於 CI/CD 以及 Gitlab CI,這裏也沒打算展開講,本文的目的在於實戰,若是想對 CI/CD 概念以及 Gitlab CI 當中的內容有興趣的能夠閱讀參考文獻 1-2。github
這裏推薦在 Linux 系統下學習 Docker,隨着鏡像和容器在使用上的複雜性愈來愈來,Win 下出現的坑會愈來愈多的。Gitlab CE 的搭建很簡單,直接使用官方的鏡像 docker run 就能夠了。可是在咱們這裏因爲還須要部署 Runner,多個容器的管理,使用 Docker-Compose 會更好,所以這裏採用它來進行。spring
可參考我以前寫的文章,解決 Windows Docker 安裝 Gitlab Volume 權限問題,裏面也提到了如何用 Docker-Compose 進行安裝。這裏我就直接給出配置文件了。docker
version: '3' #1 services: gitlab: image: gitlab/gitlab-ce:latest #2 container_name: "gitlab" restart: unless-stopped privileged: true hostname: "172.17.193.109:7780" #3 environment: #4 GITLAB_OMNIBUS_CONFIG: | # external_url 'http://172.17.193.109:7780' gitlab_rails["time_zone"] = "Asia/Shanghai" gitlab_rails["gitlab_shell_ssh_port"] = 7722 nginx["listen_port"] = 80 #5 ports: - "7780:80" - "7722:22" #6 volumes: - /home/cache/gitlab/config:/etc/gitlab - /home/cache/gitlab/data:/var/opt/gitlab - /home/cache/gitlab/logs:/var/log/gitlab gitlab-runner: container_name: gitlab-runner image: gitlab/gitlab-runner:latest #7 restart: always volumes: - "/var/run/docker.sock:/var/run/docker.sock" - "/home/cache/gitlab/runner-config:/etc/gitlab-runner"
具體說明以下(docker-compose.yml 的文件骨架這裏不作解釋):shell
/etc/gitlab/gitlab.rb
。該文件下的全部鍵值對均可以在這裏進行配置,容器啓動時會自動配置進去。固然也能夠在 Gitlab 容器啓動後,手動修改 gitlab.rb 文件。接下來直接在 docker-compose.yml 的根目錄運行就 ok 了。瀏覽器
docker-compose up -d
這個時候能夠看 IDEA 的 Docker 插件。
這樣就說明容器正在初始化,等待一會,打開以前配置好的 ip:port,就能看到 Gitlab 頁面了。首次使用須要重置 root 帳戶密碼。接下去就是正常的使用。gitlab-runner 先無論,後面會講到他,目前不須要作任何的配置工做, 只要正常啓動便可。
接下來咱們使用 Gitlab CI 構建的項目時一個基於 Spring Boot 的 hello world 項目,咱們先把他建立出來。爲了簡化這個過程,咱們直接在新建項目的時候選擇 Spring Boot 模板,它會爲咱們生成一個 hello world 項目,而且包含了一個 Dockerfile。
項目結構上和咱們手動建立的是同樣的。那麼這個時候準備工做基本上就作完了。在進入 Gitlab CI 的流程前,咱們能夠想象一下,在 Spring Boot 項目部署的過程當中,有哪些步驟是可讓 Gitlab CI 來完成的。咱們最終的目的是,但願經過 Gitlab CI,直接能夠將咱們 push 到遠端倉庫的代碼自動構建,並在一個新的容器中運行。那麼具體的步驟應該有 2 步:
那麼接下來的操做就是圍繞着這兩步展開的。
安裝完 Gitlab-Runner 而且建立好項目後,就須要爲咱們的項目註冊具體的 runner 來執行 CI 任務。
首先咱們打開,Gitlab 項目的設置 --->CI/CD--->Auto DevOps。看到 URL 和註冊令牌。
進入 gitlab-runner 容器內部(exec /bin/bash),執行 gitlab-runner register 開始註冊。
root@bb6040f1cd04:/# gitlab-runner register Runtime platform arch=amd64 os=linux pid=43 revision=a987417a version=12.2.0 Running in system-mode. Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com/): http://172.17.193.109:7780/ Please enter the gitlab-ci token for this runner: zpzZ-shsCVxsJDZtAPNZ Please enter the gitlab-ci description for this runner: [bb6040f1cd04]: hello,spring boot! Please enter the gitlab-ci tags for this runner (comma separated): maven,docker Registering runner... succeeded runner=zpzZ-shs Please enter the executor: docker-ssh, shell, ssh, virtualbox, docker+machine, custom, parallels, docker-ssh+machine, kubernetes, docker: docker Please enter the default Docker image (e.g. ruby:2.6): docker:latest Runner registered successfully. Feel free to start it, but if it's running already the config should be automatically reloaded!
根據步驟,依次輸入對應的值,顯示註冊成功則完成註冊。這個時候刷新 Gitlab 頁面,能夠看到剛剛註冊成功的 runner。
因爲剛剛咱們只是根據流程配置了一些基本的信息,還有額外的參數要配置就須要修改對應的配置文件了。能夠直接修改映射到本地的 /home/cache/gitlab/runner-config
目錄下的 config.toml
。每配置一個 runner 就會在配置文件中生成一個 [[runners]]。
[[runners]] name = "hello,spring boot!" url = "http://172.17.193.109:7780/" token = "u8_Y5rLQazUmBZar9eys" executor = "docker" [runners.custom_build_dir] [runners.docker] tls_verify = false image = "docker:latest" privileged = true #1 disable_entrypoint_overwrite = false oom_kill_disable = false disable_cache = false volumes = ["/cache", "/home/cg/.m2:/root/.m2"] #2 shm_size = 0 [runners.cache] [runners.cache.s3] [runners.cache.gcs]
須要修改的地方:
那麼 runner 是須要觸發才能工做的,接下來就須要配置 Gitlab-CI 了 。
容器化就是 jar 轉化爲 Docker 鏡像的過程。咱們講以前自動生成的 Dockerfile 修改一下:
FROM openjdk:8-jdk-alpine VOLUME /tmp COPY /target/demo-0.0.1-SNAPSHOT.jar app.jar ENV PORT 5000 EXPOSE $PORT ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-Dserver.port=${PORT}","-jar","/app.jar"]
而後添加 Gitlab CI 核心的配置文件——.gitlab-ci.yml
,並把它放在項目的根目錄下。Gitlab 項目在建立的時候,默認會開啓 Auto DevOps流水線,當有代碼 push 到倉庫中去的時候會自動掃描根目錄下是否包含 .gitlab-ci.yml
,若是有,會根據預約義的持續集成和持續交付配置自動化地構建、測試和部署應用程序。那麼下面來看具體的配置文件:
image: docker:latest #1 variables: #2 DOCKER_DRIVER: overlay2 DOCKER_HOST: tcp://172.17.193.109:2375 # docker host,本地可不寫 TAG: root/hello-spring:v0.1 # 鏡像名稱 cache: #3 paths: - .m2/repository services: #4 - docker:dind stages: #5 - package - deploy maven-package: #6 image: maven:3.5-jdk-8-alpine tags: - maven stage: package script: - mvn clean package -Dmaven.test.skip=true artifacts: paths: - target/*.jar build-master: #7 tags: - docker stage: deploy script: - docker build -t $TAG . - docker rm -f test || true - docker run -d --name test -p 5000:5000 $TAG only: - master
具體說明:
DOCKER_HOST
。好了,全部的配置工做都已經完成了,接下來 Git 執行 commit&push,自動構建就開始了。回到 Gitlab 頁面就能夠看到構建的過程。
能夠看到,目前的 Auto DevOps 中的流水線已經觸發了,總共會一次執行兩個階段(package、deploy)。分階段能夠查看日誌。
兩個階段都完成後,能夠直接在瀏覽器中訪問以前配置的 5000 端口,就能看見 hello,spring 的頁面了。
本文講了在 Docker 中部署 Gitlab,並嘗試使用它的 CI 功能。Gitlab CI 這類工具對於測試和生產部署仍是頗有意義的,不管是在規範性仍是便捷性上。而 Docker 提供了一個便捷的部署環境,尤爲是像目前我司這樣須要跨平臺調用的場景。