CI、CD引言
项目部署
1.将项目通过maven进行编译打包
2.将文件上传到指定的服务器中
3.将war包放到tomcat的目录中
4.通过Dockerfile将Tomcat和war包转成一个镜像,由DockerCompose去运行容器
项目更新后,需要将上述流程再次的从头到尾的执行一次,如果每次更新一次都执行一次上述操作,很费时,费力。我们就可以通过CI、CD帮助我们实现持续集成,持续交付和部署。
CI介绍
CI(continuous intergration)持续集成
持续集成:编写代码时,完成了一个功能后,立即提交代码到Git仓库中,将项目重新的构建并且测试。
1.快速发现错误。
2.防止代码偏离主分支。
搭建Gitlab服务器
准备环境
实现CI,需要使用到Gitlab远程仓库,先通过Docker搭建Gitlab
创建一个全新的虚拟机,并且至少指定4G的运行内存,4G运行内存是Gitlab推荐的内存大小。
并且安装Docker以及Docker-Compose
修改ssh的22端口
#将ssh的默认22端口,修改为60022端口,因为Gitlab需要占用22端口
vi /etc/ssh/sshd_config
PORT 22 -> 60022
# 重启sshd服务
systemctl restart sshd
# 你会发现通过ssh的60022端口连接不上主机了
# 编辑防火墙配置:
vi /etc/sysconfig/iptables
# 在最后添加:
-A INPUT -m state --state NEW -m tcp -p tcp --dport 60022 -j ACCEPT
# 重启防火墙
service iptables restart
# 如果还不行修改hosts.allow文件
vi /etc/hosts.allow
# 最后加入
sshd:ALL
# 重启
reboot
编写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.188.130'
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
注意
关闭防火墙
#关闭防火墙
systemctl disable firewalld
#重启
reboot