大家好,欢迎来到IT知识分享网。
文章目录
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、测试
结束
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/145347.html