1 CICD引言

项目部署

  • 将项目通过maven进行编译打包
  • 将文件上传到指定的服务器中
  • 将war包放到tomcat的目录中
  • 通过Dockerfile将Tomcat和war包转成一个镜像,由DockerCompose去运行容器

项目更新后,需要将上述流程再次的从头到尾的执行一次,如果每次更新一次都执行一次上述操作,很费时,费力。我们就可以通过CI、CD帮助我们实现持续集成,持续交付和部署。

2 CI介绍

CI(continuous intergration)持续集成

持续集成:编写代码时,完成了一个功能后,立即提交代码到Git仓库中,将项目重新的构建并且测试。

  • 快速发现错误。
  • 防止代码偏离主分支。

3 搭建Gitlab服务器

实现CI,需要使用到Gitlab远程仓库,先通过Docker搭建Gitlab

3.1 准备工作

  • 创建一个全新的虚拟机,并且至少指定4G的运行内存,4G运行内存是Gitlab推荐的内存大小。
  • 并且安装Docker以及Docker-Compose

3.2 修改ssh的22端口

将ssh的默认22端口,修改为60022端口,因为Gitlab需要占用22端口

vi /etc/ssh/sshd_config
  PORT 22 -> 60022
systemctl restart sshd

3.3 编写docker-compose.yml

docker-compose.yml文件去安装gitlab(下载和运行的时间比较长的)

version: '3.1'
services:
 gitlab:
  image: 'twang2218/gitlab-ce-zh:11.1.4'
  container_name: "gitlab"
  restart: always
  privileged: true
  hostname: 'gitlab'
  environment:
   TZ: 'Asia/Shanghai'
   GITLAB_OMNIBUS_CONFIG: |
    external_url 'http://192.168.199.110'
    gitlab_rails['time_zone'] = 'Asia/Shanghai'
    gitlab_rails['smtp_enable'] = true
    gitlab_rails['gitlab_shell_ssh_port'] = 22
  ports:
   - '80:80'
   - '443:443'
   - '22:22'
  volumes:
   - /opt/docker_gitlab/config:/etc/gitlab
   - /opt/docker_gitlab/data:/var/opt/gitlab
   - /opt/docker_gitlab/logs:/var/log/gitlab

4 搭建GitlabRunner

查看资料中的gitlab-runner文件即可安装

5 整合项目入门测试

5.1 创建项目

创建maven工程,添加web.xml文件,编写html页面

5.2 编写.gitlab-ci.yml

编写.gitlab-ci.yml文件

stages:
  - test

test:
  stage: test
  script:
    - echo first test ci   # 输入的命令

5.3 将maven工程推送到gitlab中

执行git命令推送到Gitlab

git push origin master

5.4 查看效果

可以在gitlab中查看到gitlab-ci.yml编写的内容

6 完善项目配置

添加Dockerfile以及docker-compose.yml, 并修改.gitlab-ci.yml文件

6.1 创建Dockerfile

# Dockerfile
FROM daocloud.io/library/tomcat:8.5.15-jre8
COPY testci.war /usr/local/tomcat/webapps

6.2 创建docker-compose.yml

# docker-compose.yml
version: "3.1"
services:
  testci:
    build: docker
    restart: always
    container_name: testci
    ports:
      - 8080:8080

6.3 修改.gitlab-ci.yml

# ci.yml
stages:
  - test

test:
  stage: test
  script:
    - echo first test ci
    - /usr/local/maven/apache-maven-3.6.3/bin/mvn package
    - cp target/testci-1.0-SNAPSHOT.war docker/testci.war
    - docker-compose down
    - docker-compose up -d --build
    - docker rmi $(docker images -qf dangling=true)

6.4 测试

7 CD介绍

CD(持续交付,持续部署)

持续交付:将代码交付给专业的测试团队去测试

持续部署:可以直接将指定好tag的代码直接部署到生产环境中

8 安装Jenkins

8.1 编写docker-compose.yml

官网:https://www.jenkins.io/

version: "3.1"
services:
  jenkins:
   image: jenkins/jenkins
   restart: always
   container_name: jenkins
   ports:
     - 8888:8080
     - 50000:50000
   volumes:
     - ./data:/var/jenkins_home

8.2 运行并访问Jenkins

第一次运行时,会因为data目录没有权限,导致启动失败

chmod 777 data

访问http://192.168.199.109:8888

访问速度奇慢无比。。。。。

访问成功后,需要输入密码,可在日志中查看

手动指定插件安装:指定下面两个插件即可

publish ssh.

git param.

安装成功后,需要指定上用户名和密码,登陆成功

9 配置Jenkins的目标服务器

执行过程为代码提交到Gitlab,Jenkins会从Gitlab中拉取代码,并在Jenkins中打包并发布到目标服务器中。

9.1 点击左侧的系统设置

左侧导航

Manage Jenkins

9.2 选中中间区域的系统设置

系统设置

Configure System

Confiqure global settings and paths

9.3 搜索Publish over SSH

Publish over SSH 下一步点击新增

9.4 点击上图新增

新增SSH连接

接上一步新增

输入Linux登录密码

10 配置GitLab免密码登录

链接Gitlab需要使用密码,我们可以通过SSH的方式,免密码登陆Gitlab拉取代码,避免每次都输入密码。

10.1登录Jenkins容器内部

docker exec -it jenkins bash

10.2 输入生成SSH秘钥命令

ssh-keygen -t rsa -C "邮箱(随便写)"

10.3将秘钥复制到GitLab的SSH中

11 配置JDK和Maven

我们需要再Jenkins中将代码打包,需要依赖JDK和Maven的环境

  1. 复制软件到data目录下

  2. 在监控界面中配置JDK和Maven

  3. 手动拉取gitlab项目

    使用SSH无密码连接时,第一次连接需要手动确定

12 创建maven任务

实现通过Jenkins的Maven任务,自动去Gitlab拉取代码,并在本地打包,发布到目标服务器上

12.1 创建maven工程,推送到GitLab中

随便创建一个即可……

12.2 Jenkins的监控页面中创建maven任务

  • 指定GitLab地址
  • 指定maven打包方式

12.3 执行maven任务

  1. 点击立即构建,并查看日志
  2. 控制台查看日志信息

12.4 最终效果

打包成功显示 test- 1.0-SNAPSHOT.WAR

13 实现持续交付持续部署

实现根据tag标签,实现持续交付和持续部署

13.1 安装Persistent Parameter的插件

安装Persistent Parameter插件,勾选Build Paramenters

13.2 重新指定构建项目的方式

  • 根据标签构建项目
  • 自定义构建

13.3 构建项目成功后,需要将内容发布到目标服务器

发布服务器后执行的命令

Send build artifacts over SSH – SSH Publishers – SSH Server – Transfers – Exec command

  • docker image prune -f

13.4 添加程序代码

# Dockerfile 文件
FROM daocloud.io/library/tomcat:8.5.15-jre8
COPY testcd-1.0-SNAPSHOT.war /usr/local/tomcat/webapps

# docker-compose.yml文件
version: "3.1"
services:
  testcd:
    build: docker
    restart: always
    container_name: testcd
    ports:
      - 8081:8080

13.5 测试

根据标签修改发布版本

Build with Paramenters —> 勾选需要构建项目的参数即可

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐