【Docker】- 03 Docker CI、CD(CI、CD、项目配置、环境部署)
CI(continuous intergration)持续集成持续集成:编写代码时,完成了一个功能后,立即提交代码到Git仓库中,将项目重新的构建并且测试。快速发现错误。防止代码偏离主分支。CD(持续交付,持续部署)持续交付:将代码交付给专业的测试团队去测试持续部署:可以直接将指定好tag的代码直接部署到生产环境中。
Docker CI、CD(CI、CD、项目配置、环境部署)
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的环境
复制软件到data目录下
在监控界面中配置JDK和Maven
手动拉取gitlab项目
使用SSH无密码连接时,第一次连接需要手动确定
12 创建maven任务
实现通过Jenkins的Maven任务,自动去Gitlab拉取代码,并在本地打包,发布到目标服务器上
12.1 创建maven工程,推送到GitLab中
随便创建一个即可……
12.2 Jenkins的监控页面中创建maven任务
- 指定GitLab地址
- 指定maven打包方式
12.3 执行maven任务
- 点击立即构建,并查看日志
- 控制台查看日志信息
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 —> 勾选需要构建项目的参数即可
,
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)