Docker的CICD

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值