本文首发于个人我的博客,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 提供了一个便捷的部署环境,尤为是像目前我司这样须要跨平台调用的场景。