团队有集成测试的需求,集成测试需要依赖一些中间件,比如mysql,rabbitmq。每个研发人员有对自己开发的那部分代码进行测试编写和运行检测的需求。
为了不互相影响,可以选择在研发本地搭建自己的依赖环境,我们希望这些环境搭建要容易、快速,且方便清理。
而docker,则能很好实现上述诉求。
但仅仅这样还不够,我们还面临着以下一些问题
总结来看,使用docker可以帮助我们快速的搭建项目依赖环境,但是本地化的docker依赖,依然让我们的代码在测试时,不够纯粹,对其各个运行环境,都有有本地docker安装的要求。
而实际上,docker本身提供了远程链接模式,则使得我们可以中心化的部署docker,然后集成测试代码以tcp链接的方式,使用docker server,进行依赖中间件搭建,测试。
以centos 为例7.6为例,讲解如何将一个docker配置成可以远程链接。
在/etc/docker/daemon.json
中开启远程链接端口
{"hosts": ["tcp://0.0.0.0:2375", "unix:///var/run/docker.sock"]}
添加文件/etc/systemd/system/docker.service.d/override.conf
,注意上述路径不存在则手动创建
[Service] ExecStart= ExecStart=/usr/bin/dockerd
systemctl daemon-reload
systemctl restart docker.service
在部署好远程docker后,随之而来的问题是
幸运的是,框架,帮我们很好的解决了上述问题。
更进一步的,游戏公司提供了Testcontainers 同spring boot整合的测试框架https://github.com/Playtika/testcontainers-spring-boot
,使得Spring Boot或Spring cloud生态的应用在编写集成测试时,更方便
使用Testcontainers 或 playtika的testcontainers-spring-boot进行远程docker链接时,都不需要在本地安装docker客户端。但需要进行相关环境变量配置,使得代码可以知道远程docker的地址。该地址的配置有如下几种方式
DOCKER_HOST=tcp://remote_docker_server_ip:2375
System.setProperty("DOCKER_HOST","tcp://remote_docker_server_ip:2375")
指定环境变量上述测试代码不需要安装docker 客户端。但倘若我们需要以命令行的方式,管理docker,则可以安装一些docker客户端,来跟远程docker通信。当然上述的Testcontainers 相当于客户端的一种。
不同操作系统的客户端程序安装方式见:
参考资料
到此这篇关于使用远程Docker进行集成测试的文章就介绍到这了,更多相关Docker集成测试内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
免责声明:本站发布的内容(图片、视频和文字)以原创、来自本网站内容采集于网络互联网转载等其它媒体和分享为主,内容观点不代表本网站立场,如侵犯了原作者的版权,请告知一经查实,将立刻删除涉嫌侵权内容,联系我们QQ:712375056,同时欢迎投稿传递力量。
Copyright © 2009-2022 56dr.com. All Rights Reserved. 特网科技 特网云 版权所有 特网科技 粤ICP备16109289号
域名注册服务机构:阿里云计算有限公司(万网) 域名服务机构:烟台帝思普网络科技有限公司(DNSPod) CDN服务:阿里云计算有限公司 百度云 中国互联网举报中心 增值电信业务经营许可证B2
建议您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流浏览器浏览本网站