Docker基础(四)——DI、CD

Docker DI、CD

1.引言

项目部署

1、将项目通过maven进行编译打包

2、将文件上传到指定的服务器中

3、将war包放到tomcat的目录中

4、通过Dockerfile将Tomcat和war包转成一个镜像,由DockerCompose去运行容器

项目更新了

​ 将上述流程再次的从头到尾的执行一次

2.CI介绍

CI(continuous intergration)持续集成

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

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

3.实现持续集成

3.1 搭建Gitlab服务器

1、创建一个全新的虚拟机,并且至少指定4G的运行内存

2、安装docker以及docker-compose

3、将ssh的默认22端口,修改为60022端口

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

4、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

3.2 搭建Gitlab-Runner

3.3 整合项目入门测试

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

2、编写gitlab-ci.yml文件

stages:
  - test

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

3、将maven工程推送到gitlab中

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

打开gitlab控制台-左侧CI/CD-流水线-已通过

在这里插入图片描述

3.4编写.gitlab-ci.yml文件

1、编写.gitlab-ci.yml测试命令使用

stages:
  - test

test:
  stage: test
  script:
    - echo first test ci
    - /usr/local/maven/apache-maven-3.6.3/bin/mvn package

2、编写关于dockerfile以及dock er-compose.yml文件的具体内容

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

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

# 3. 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)

3、测试
在这里插入图片描述

4.CD介绍

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

5.实现持续交付持续部署

5.1 安装Jenkins

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

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

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

chmod 777 data

访问http://192.168.199.109:8888

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

输入密码

> 这里是引用

手动指定插件安装:指定下面两个插件即可
Publish ssh
git param…

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

在这里插入图片描述

5.2 配置目标服务器以及Gitlab免密码登录

Gitlab -> Jenkins -> 目标服务器

1、Jenkins去连接目标服务器

左侧的系统设置

在这里插入图片描述

选中系统设置

在这里插入图片描述

搜索Publish over SSH

在这里插入图片描述

点击新增

在这里插入图片描述

5.3 配置Gitlab免密码登录

1、登录Jenkins容器内部

docker exec -it jenkins bash

2、输入生成SSH密钥命令

ssh-keygen -t rsa -C "邮箱"

3、将密钥复制到Gitlab的SSH中

在这里插入图片描述

5.4 配置JDK和Maven

1、复制本地的jdk和maven的压缩包到data目录下

2、手动解压

在这里插入图片描述

3、在监控界面中配置JDK和Maven

在这里插入图片描述

5.5 手动拉取gitlab项目

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

在这里插入图片描述

5.6 创建maven任务

1、创建maven工程,推送到gitlab

2、jenkins的监控页面中创建maven任务

在这里插入图片描述
在这里插入图片描述

3、执行maven任务

在这里插入图片描述
在这里插入图片描述

4、最终效果

在这里插入图片描述

6.实现持续交付持续部署

1、安装Git Parameter的插件,Persistent Parameter的插件(版本)

![](https://img-blog.csdnimg.cn/4c8f1b2266d5424aa46d8d24f5f9411c.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAcXFfNTIwMDY5NDg=,size_20,color_FFFFFF,t_70,g_se,x_16)

2、重新制定构建项目的方式

在这里插入图片描述

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

在这里插入图片描述

4、修改程序代码,(提交到GitLab仓库中)

FROM daocloud.io/library/tomcat:8.5.15-jre8
COPY testcd-1.0-SNAPSHOT.war /usr/local/tomcat/webapps
version: '3.1'
services:
  testcd:
    build: docker
    restart: always
    container_name: testcd
    ports:
      - 8081:8080

5、测试

1.给当前代码添加一个标签
2.到Jenkins中查看

在这里插入图片描述

3.点击上图的开始构建(查看日志)
4.去指定的目标服务器中访问具体服务

结束

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值