失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 使用docker实现半自动化代码自动部署与回滚

使用docker实现半自动化代码自动部署与回滚

时间:2021-01-05 09:56:48

相关推荐

使用docker实现半自动化代码自动部署与回滚

最近开发docker的caas平台,目前已经开发完成,在优化性能与套模板。对于docker最近是很好,很多人把docker做为vm来使用,当然作为测试来说是没问题,但我感觉docker本身在做沙箱、自动化部署与回滚方面更适合,下面介绍一下我这里是如何通过docker实现代码半自动化部署。

目前我这里已经实现能结合svn或者git代码库,对node、php、java代码进行半自动化部署,先给大家截图看效果,感觉满意在继续细看。

总界面如下

点击左上角的“新增开放项目”就可以新建立测试,下面是功能截图:

默认情况下,这个操作跟容器创建类似,后期我也打算把容器管理跟程序开发管理合并。

代码存放支持2种,分别是svn存放:

以及git存放:

平台支持PHP、node、java这3中代码类型,默认类型为PHP。

接下来我们进入实测演练即如何使用平台进行快速代码更新:

我将通过2个测试实例来帮助大家理解。

测试需求一:对基于存放svn库的java代码进行快速的部署与测试

假如当前当前SVN库版本为13,文件内容如下:

test6.jsp文件内容如下:

接下来选择镜像(java代码,当然选CentOS6系统 + Tomcat镜像,然后输入好SVN信息)来创建测试:

鉴于Tomcat比较费内存,所以选择1G的内存,ssh密码验证方式,然后创建测试:

创建成功后,右侧会有弹框提示:

下一步就是设置防火墙,或者绑定公网IP后再做防火墙。我们使用空闲IP xxx.xxx.57.182来设置:

绑定成功之后,设置防火墙:

默认是没有规则,所以规则一栏显示红色的无。

新增完成后,再点击Apply(点击这个主要是防止修改错规则)生效。当前的防火墙规则为:

如此,我们可以通过xxx.xxx.57.182:8080/container_name/file/filename来访问(由于是tomcat业务,代码是java,我容器里把代码自动打成了war包,所以访问的格式是这样,并且能在web直接访问):

可以看到,使用xxx.xxx.57.182:8080/container_name/file/filename访问的内容,就是svn根目录里的内容。

登陆容器,在代码目录下可以看到一个以container_name命名的war包,里面包含SVN库中所有的文件。

修改一下SVN里test6.jsp文件内容如下,并且提交之后当前版本是14:

然后,进入程序开发模块,并选择update把14版本内容发布:

点击确定等待结果:

登录WEB界面查看,结果有了相应的变化:

自然,平台也提供了代码回滚功能,即如果我想将代码回滚到版本13,步骤如下:

点击确认后,再回到WEB界面查看,代码已经回到先前的版本13:

测试需求二:对基于存放git库的php代码进行快速部署与测试

首先查看一下git库信息:

这个是一个gitlab服务,里面有几个文件,先看看test3.html内容:

接下来,利用我们的CaaS平台来构建PHP模式的测试项目:

选择好Nginx-php的镜像,然后输入git信息,之后就可以直接创建了:

这次不使用公网IP,直接使用防火墙,通过宿主机IP+自动生成的端口进行外网访问,并允许我公司的公网IPxxx.xxx.170.157/32访问容器的80端口:

这个规则就是允许外部访问端口为40005,因此我们通过宿主机ip+40005端口访问查看结果:

浏览器中返回的内容便是先前在git库中查看内容。接着我修改git代码信息如下:

返回平台,更新代码:

再通过WEB页面访问,会看到返回已经有了相应的变化:

同理,我们来进行一次回滚测试。我们使用git log 查询到之前版本的hash:

回滚到上图选定的版本,可以在平台如下配置:

提示成功后,查看WEB 页面,可以看到已经回滚成功:

至此,本次测试的2个实例都已经成功完成!

以后开发使用这个平台就可以快速的进行代码测试,中间不需要运维参与,大大的节省了中间的很多环节与时间,能对公司的deveop快速代码部署有很大的方便。

如何实现?

前端使用tornado+bootstrap,后端是python,通信使用socket+ssl。

我这里仅提供一下我是如何使用docker做半自动化代码部署,介绍一下功能与其他截图,大家可以自己根据需求来开发。

如果觉得《使用docker实现半自动化代码自动部署与回滚》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。