• 0
  • 0
分享
  • 对docker的简单理解——软件测试圈
  • 落叶凌飒 2024-07-08 16:30:05 字数 2493 阅读 303 收藏 0

  一款产品从开发到上线,从操作系统,到运行环境,再到应用配置。作为开发+运维之间的协作,我们需要关心很多东西,这也是很多互联网公司都不得不面对的问题,特别是各种版本的迭代之后,不同版本环境的兼容,对运维人员都是考验。环境配置如此麻烦,换一台机器,就要重来一次,费时费力。很多人就在想,能不能从根本上解决问题,软件可以带环境安装?也就是说,安装的时候,把原始环境一摸一样的复制过来。开发人员利用docker可以消除协作编码时“在我电脑上是正常的呀”的问题。

  Docker之所以发展如此迅速,也是因为它对此给出了一个标准化的解决方案

  之前在服务器配置一个应用的运行环境,要安装各种软件,比如,java/tomcat/mysql/jdbc驱动包等等,还有各种中间件mqtt,zookeeper等等,安装和配置这些东西有多麻烦就不说了,它还不能跨平台。假如我们是在windows上安装的这些环境,到了linux又得重新安装。况且就算不跨操作系统,换另一台同样操作系统的服务器,要移植应用也是非常麻烦,相当于又要重复的部署。几台服务器还好说,万一哪天领导安排一项任务,运维的同事要在40台服务器上部署应用,每一台都重新配置搞环境,岂不是忙不过来;假设,有一套已配置好的全家桶,直接放在每一台服务器上就可以跑起来正常使用,那就方便多了。传统上认为,软件编码开发并测试结束后,所产出的成果即程序。而为了让这些程序可以顺利执行,开发团队也得准备完整的部署文件,让运维团队得以部署应用程序。开发需要清楚的告诉运维部署团队,用的全部的配置文件+所有软件环境。不过即便如此,也仍然常常发生部署失败的状况。Docker镜像的设计,使得docker打破过去的旧观念。透过镜像(images)将作业系统核心除外,运作应用程序所需要的系统环境,由下而上打包,达到应用程序跨平台间的无缝接轨运作

  一、docker的基本概念

  1.1docker是什么?

2-1.png

  ①Docker是基于Go语言实现的云开源项目

  ②Docker的主要目标是“Build,ShipandRunAnyApp,Anywhere”,构建、安装、运行任何应用在任何平台;也就是通过对应用组建的封装、分发、部署、运行等生命周期的管理,使用户的APP及其运行环境能够做到“一次封装,到处运行”

  ③Linux容器技术的出现就解决了这样的一个问题,而docker就是在它的基础上发展过来的,将应用运行在docker容器上面,而docker容器在任何操作系统上都是一致的,这就实现了跨平台、跨服务器。只需要一次配置好环境,换到别的机子上就可以一键部署,大大简化了操作

  一句话:解决了运行环境和配置问题软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术

  1.2docker能干什么?

  ①Docker和传统虚拟化方式的不同之处

  *传统虚拟机技术是虚拟出一套硬件后,在其上运行一个完整操作系统,在该系统上再运行所需应用进程

  *而容器内的应用进程直接运行于宿主机的内核,容器内没有自己的内核,而且也没有进行硬件虚拟,因为,容器要比传统虚拟机更为轻便

  *每个容器之间互相隔离,每个容器都有自己的文件系统,容器之间进程不会互相影响,能区分计算资源

  ②传统虚拟机的缺点:

  资源占用多,冗余步骤多,启动慢

  ③Docker的优势:

  ·轻量、秒级的快速启动速度

  · 简单,易用

  · 标准统一的打包/部署/运行方案

  · 镜像支持增量分发,易于部署

  · 易于构建,适合自动化测试和持续集成

  1.3docker去哪里下载?

  docker官网:http://www.docker.com

  Docker中文网站:https://www.docker-cn.com/

  自学的话,下一个社区版就可以,免费使用就行

  1.4docker的三要素:镜像、容器、仓库

2.png

  镜像、容器、仓库,怎么来理解这三个概念?

  ①镜像就是一个只读的模板,镜像可以用来创建docker容器,一个镜像可以创建很多个容器

  ②容器是镜像创建出来的实例,它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。可以把容器看作是一个简易版的Linux环境

  ③仓库是集中存放镜像文件的场所;仓库和仓库注册服务器是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签,

  仓库分为公开仓库和私有仓库两种形式,最大的公开仓库是https://hub.docker.com/,里面存放着数量庞大的镜像供用户下载。国内的公开仓库包括阿里云,网易云等等。

  ---------需要正确理解以上三个要素的概念----------:

  Docker本身就是一个容器运行载体或者称之为管理引擎。我们把应用程序和配置依赖打包好形成一个可交付的运行环境,这个打包好的运行环境就似乎image镜像文件,只有通过这个镜像文件才能生成Docker容器,image文件可以看作是容器的模板,docker根据image文件生成容器的实例同一个image文件,可以生产多个同时运行的容器实例。

  *image文件生成的容器实例,本身也是一个文件,成为镜像文件

  *一个容器运行一种服务,当我们需要的时候,就可以通过docker客户创建一个对应的运行实例,也就是我们的容器

  *至于仓储,就是放了一堆镜像的地方,我们可以把镜像发布到仓储中,需要的时候,从仓储中拉下来就可以了。


作者:excellent_1   

来源:http://www.51testing.com/html/46/n-7796746.html

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          •   Locust介绍  Locust是一款使用Python开发的开源性能测试工具,支持分布式,可在多台主机上对系统持续发送请求,与Jmeter、LoadRunner的等压测工具使用线程的方式模拟用户请求不同,Locust是使用协程的方式模拟用户请求,协程的上下文切换是由自己控制,当一个协程执行完成后会主动让出,让另一个协程开始执行,切换是在用户态完成的,而线程切换是受系统控制,是在用户态与内核态之间切换,所以协程上下文切换的代价远比线程切换的代价小的多,因此Locust可以达到更高数量级的并发。  Locust安装  需要先安装python3.6以上版本,然后再安装Locust。  pip&n...
            0 0 1201
            分享
          •   对于经常接触代码的人来说,git以及github并不陌生。但是对于刚接触git环境的人,尤其是对于测试人来说,使用起来还是有一定难度的。  我想大部人对于这块的疑问有可能存在下面的几点:  1.没有全局观,不理解每个工具实现的功能,也就是不理解原理,只知道直接照着网上的教程走,以至于出现问题,不知道如何解决。  2.有的资料是直接命令,有的是通过工具,也就是实现方式不唯一,不确定自己到底想要以什么方式实现。  3.不知道注意的点。缺少技巧,比如某个命令执行了,但是就是不生效,原因有可能是一类问题。  针对上面的问题,逐一简单介绍一下。  每个工具职责  pycharm  pycharm是p...
            15 15 1923
            分享
          • 一、准备1.1 下载Postman 软件postman下载https://www.postman.com/1.2 首先把要进行压力测试的接口,进行测试,显示没有问题,状态为200二、压力测试步骤2.1 在接口处,设置参数,{{}}包住参数!外面还有双引号!2.2 选择Pre-request-Script,对变量进行编写代码postman.setEnvironmentVariable("openid",data["openid"]);2.3 一定不要忘了写断言,不然运行的时候总会提示一句话,额!具体我忘了截图,你遇到就知道了pm.test("St...
            0 0 2487
            分享
          • 读者提问:研发质量差,怎么办 ?阿常回答:这个问题乍一看,咱们作为测试好像管不着,那我们可以做些什么呢。一、作为测试无法保证质量测试人员的职责是在软件产品发布前,尽可能多地 、快速暴露有价值的缺陷,加速可交付质量的达成。测试人员虽然无法保证研发质量,但可以控制测试质量和测试进度,并且在测试结束后对于研发质量做出评价。一)控制测试质量和测试进度1、做好测试计划,准备好测试需要的工具和软件,好的规划是成功的一半。2、编写测试用例,最好进行一次用例评审,避免漏测重要的 case。3、开发提测前进行冒烟测试,冒烟测试通过后方可正式移交测试。4、及时汇报测试进度,用例执行情况、BUG 修复情况...
            0 0 720
            分享
          •   对业务指标的要求主要有:请求响应时间,最大并发量等等。  对系统资源的指标,如:资源使用率是指在系统负载运行期间,数据库服务器,应用服务器,web服务器的cpu,内存,硬盘,外置存储,网络带宽的使用率,低于20%的使用率为资源使用稳定,60%-80%的使用率表示资源使用饱和,超过80%的使用率的资源使用率必须尽快进行资源调整和优化。  1) 业务指标  2) 系统资源指标  根据测试目的不同,需要统的系统资源指标也不同。主要包括以下一些:服务器操作系统资源使用情况,各种服务器的资源消耗情况等等。  内存  Paging rate:内存页交换速率  如果该值偶尔走高,表明当前有线程竞争内存。...
            0 0 819
            分享
      • 51testing软件测试圈微信