文章目录
Docker DI、CD
1.引言
2.CI介绍
3.实现持续集成
3.1 搭建Gitlab服务器
3.2 搭建Gitlab-Runner
3.3 整合项目入门测试
3.4编写.gitlab-ci.yml文件
4.CD介绍
5.实现持续交付持续部署
5.1 安装Jenkins
5.2 配置目标服务器以及Gitlab免密码登录
5.3 配置Gitlab免密码登录
5.4 配置JDK和Maven
5.5 手动拉取gitlab项目
5.6 创建maven任务
6.实现持续交付持续部署
结束
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
点击新增