教育装备采购网
第七届图书馆 校体购1

ZStack实践汇 高效开发测试打造产品化私有云

教育装备采购网 2019-07-18 13:43 围观1264次

 前言

  随着越来越多的企业将云计算产品应用到基础设施及其核心业务中,如何提高和保证软件交付质量、减少软件开发迭代周期、加速软件发布频率成为所有云厂商面临的关键问题。

  根据IDC 2018年的预测,中国云计算市场在未来5年将持续高速发展的态势,主要表现为:中国传统的非云计算IT基础架构占整体IT基础架构的投入比例将从2018年的50.3%下降到2022年的40.7%;中国私有云平台建设的市场规模将以年均24.8%的复合增长率快速增长;中国云计算IT基础架构支出占全球市场比将从2018年的12%上升到2022年的25%,届时中国私有云IT基础架构支出将超过美国,成为全球第一大市场。在这一轮新的迭代更新中,更多的企业和行业开始部署或者建立更大规模的私有云;而新应用(数据分析,AI,IoT,移动)和新场景(边缘计算,智慧/平安城市,行业云)也对云平台提出了更高的需求。

  ZStack凭借创新的产品化理念,在业内率先提出云计算的4S标准 – 简单Simple,健壮Strong,弹性Scalable,智能Smart。同时,ZStack企业版从第一版发布到最新的3.5.0版本,一直以每六周一次的周期迭代更新软件版本,快速提升和扩展产品功能,积极应对云计算市场对私有云产品不断增长的需求。而保证其私有云产品化的关键要素有以下三点:

   1、 流程 – 快速敏捷

   2、 运维 – 智能高效

   3、测试 – 严谨全面

  注:ZStack坚持快速、简洁、高效的开发、运维、测试流程,确保新需求六周便可实现

 1. 流程-快速敏捷

  ZStack开发流程依然定义了传统开发模式中的几个关键阶段 - FF、CF、RC和GA。同时针对不同阶段的任务和目标,进行有的放矢地优化。在Feature Freeze阶段,主要以需求分析为主,要求产品经理将客户的需求分片化、分级化,需求描述本地化,更有效地将需求安排到不同发布版本周期中。开发和测试工程师则需要将Code Freeze和Release Candidate的任务提前到Feature Freeze阶段中,减少互相之间任务的依赖,提高各个阶段的并发度。而测试不仅需要渗透到开发的每个环节中,同时也要通过模型测试、路径测试、稳定性测试等方法,提高代码的覆盖度和测试效率。每个发布周期通过反复地从需求->开发->测试的快速迭代,保证了产品的新需求和问题始终能够被快速满足和解决。

 

  注:ZStack产品开发流程高度并发,保证版本之间快速迭代

 2. 运维-智能高效

  作为私有云产品开发的基础保证,一套快速、稳定、高并发、可伸缩的运维系统是必要的。而传统运维提供的简单CI和CD功能是显然无法满足这样快速迭代的需求。ZStack产品化过程中,搭建了一套以ZStack Kubernetes为基础、面向公司各个部门的整体性服务框架。这套框架中所包括的服务内容涵盖从开发&测试人员使用的测试环境、到整个项目的管理工具。框架的底层以ZStack作为IaaS提供给上层可靠的、可扩展的物理资源,同时结合Kubernetes,将容器运行于云主机中,既保证了隔离性、又充分利用了ZStack和Kubernetes对云主机和Docker调度的优势,起到了对上层服务高可用、高并发及可伸缩的双重保障。

 

  注:ZStack作为IaaS层向上层服务提供可靠的物理资源,而更重要的是,内部的ZStack环境也会随着发布版本更新,真正做到了自己的产品自己先用起来。

 

  注:实际生产环境中,一次自动化测试至少在Jenkins上并发创建500 个请求,每个请求包含10~50个测试用例,ZStack Kubernetes保证了这些请求几秒内可以被处理

 3. 测试-严谨全面

  打造一个产品化的私有云软件需要全面且严谨的测试,这不仅仅是单元测试和集成测试能保证的。ZStack从以下四个方面入手强化测试:

  3.1  测试高效化:整个产品流程中开发和测试要同步进行,这包括了对不同的开发分支需要有不同深度的测试代码保证其质量——例如,对于Release分支,必须有持续性的Nightly测试把控每天进入的代码质量;对于Feature分支,需要能快速检测出patch对代码核心功能影响的BAT测试。同时测试系统和CI系统要高度集成并且做到同步触发。

  高效化的另一个重点就是要做到所有测试都能运行在云端,提高测试的并发度和资源利用率。ZStack内部的测试都是跑在云端的,而云端环境也是基于ZStack自身搭建的,利用其对底层硬件资源的抽象和管理,模拟出测试中需要的不同的硬件配置场景,包括网络、存储、虚拟化平台、甚至不同的ZStack高级功能配置,如企业管理、灾备服务等。同时,为了满足大规模资源需求的测试场景,例如1万台或10万台云主机的测试场景,ZStack测试中还实现了simulator机制,即不真实分配硬件资源,而使用mock后端API的方式提供了对后端资源的调配,真正做到了有针对性的测试。

  注:ZStack云端测试的环境构建是通过XML配置文件实现的,测试工程师可以非常简单地用几分钟配置出一台自动化环境。

  3.2 测试标准化:ZStack所涵盖的测试内容不仅包括功能性测试,还包括一套完整测试体系所需要的各种测试,如开发工程师需要做的集成/单元测试,测试工程师需要做的系统测试中的压力、性能、可靠性测试、以及针对不同版本定制的发布测试。例如ZStack的可靠性测试就包括了两类测试 – MTBF和DPMO测试,MTBF会对ZStack平台进行15,000小时长时间的真实用户操作模拟;DPMO测试则会对ZStack平台进行高达10,000次的断/上电、重启等测试。

  标准化的另一方面体现在对关键节点的标准把控上,对FF、CF、RC和GA各个阶段都会有相应的代码准入和验收标准,例如CF阶段后功能开发代码禁止进入发布分支而只能进入下一个发布版本的周期;又例如各个阶段验收时要求的bug数量限制,CF阶段要求小于5个P0,GA阶段要求没有P0的bug。

  3.3 测试覆盖智能化:软件测试没法达到100%的覆盖率,所以我们要做的是在资源有限的情况下,以尽量少的代价做到尽可能高的覆盖率。要提高覆盖率,需从两方面入手,一方面是对代码进行覆盖率检查,我们在日常CI的包中插入了代码不同模块的覆盖率,不管是手动还是自动测试,或是日常bug的验证,都会为覆盖率提供数据。

  另一方面我们增加了模型测试,它可以产生由随机API组合构成的场景,会持续运行直到遇到预定义的退出条件或者找到一个缺陷。这种模型测试很好地弥补了人为定义用例的不足,提高了测试场景和路径的覆盖率。由这种测试模型,也衍生出了三种不同场景的覆盖率提高测试:

  3.3.1 覆盖率测试:

  除常规有序的测试步骤外,运用模型测试,收集无序测试步骤下的测试覆盖率。

  3.3.2 MTBF测试:

  从有序和无序两种测试维度,对系统稳定性及可靠性进行测试。

  3.3.3 路径测试

  通常一个系统测试用例最多5~6个操作步骤,而最终客户的问题场景是极其复杂的,通常需要10~20个以上的步骤才能重现,运用模型测试的方法,可以有效减少构建测试用例的代码量。

  注:一个典型路径测试,只需要将测试对象和操作步骤写到测试用例中即可完成

  3.4 报告立体化:主要从两方面实现,一是测试报告的结果自动化、可读化,是通过对测试用例中插入DITA描述实现的。另一方面是结果的可追溯和可回放,这是通过记录测试过程中API的调用顺序和参数实现的。

  注:一个测试结果的操作记录及回放方法,能够有效帮助开发测试工程师重现bug

 总结

  作为产品化的云计算公司,ZStack一直致力于打造自研的ZStack私有云、ZStack混合云、ZStackMini超融合一体机、ZStack CMP多云管理平台、ZStack企业级分布式存储等产品和方案。本文从开发流程、基础运维以及测试能效等角度,介绍了 ZStack 团队如何高效打造一个产品化的私有云。

来源:ZStack 责任编辑:阳光 我要投稿
校体购终极页

相关阅读

  • 华为云云耀云服务器HECS荣获CSDN年度创新产品与解决方案大奖

    华为云云耀云服务器HECS荣获CSDN年度创新产品与解决方案大奖
    IT专家网01-13
    日前,“CSDN2022中国开发者影响力年度评选”活动榜单正式揭晓。该评选活动由全球知名中文开发者网站CSDN和旗下重要的技术类期刊杂志《新程序员》联合...
  • ZStack Cloud助力浙江财经大学打造超融合云平台

    ZStack Cloud助力浙江财经大学打造超融合云平台
    ZStack07-19
    随着校园业务系统的增多与数据量的增大,浙江财经大学急需建立一个能够统一管理资源池的信息化平台。ZStackCloud私有云平台以超融合技术构建了统一资源...
  • 上海市2022届高校毕业生春季系列网络招聘今启动
    上海市教育委员会04-14
    受新冠疫情影响,上海市当前就业形势正面临严峻考验,为坚决贯彻落实习近平总书记重要指示精神,加强就业形势分析研判,为2022届毕业生送岗位、送政策、送指导,坚决打赢抗疫和毕业生充分就业攻...
  • 线上全敲定 安徽医科大学打造毕业生就业“云服务”新平台

    线上全敲定 安徽医科大学打造毕业生就业“云服务”新平台
    安徽省教育厅12-10
    “392家单位参加,其中三级医院单位88家,招聘人数24232人,累计接受投递简历数4790份。”这是刚刚结束的安徽医科大学与国内知名医疗科普网站丁香园共...
  • 云服务将为视听行业带来稳定的收入增长

    云服务将为视听行业带来稳定的收入增长
    奥图码数码科技(上海)有限公司11-02
    固定收入不是一个想法或目标,而是经营任何业务的基础。这是衡量我们成功与否的标准;这是我们成长的工具;最重要的是,这是我们谋生的关键。每当发生...
  • 中国煤炭教育赋能云平台与SIT中国达成战略合作
    中国煤炭教育赋能云平台01-19
    2020年1月9日,中国煤炭教育赋能云平台与SIT中国正式签订战略合作协议。双方将在“创新教育课程体系共建、专家团队教研合作、国内及全球创新研学”等方面进行深度合作,把创新思维和基因融入教育...
  • ZStack产品化磁场 吸引伙伴强劲合力
    ZStack08-26
    ​生态在IT业不是一个新词,但是个热词,这个提法是随着客户需求而生的,当客户面临云、大数据、AI等新技术时,需要更全面的整体解决方案。在面临客户数字化转型的背景下,没有一个供应商可以全...
  • ZStack云贵首秀:伙伴助阵 实力加持
    ZStack07-02
    ​6月18日,ZStack全国巡展活动走入云贵,在昆明站联合阿里云和云南天成强势布局,吸引了当地近百名渠道伙伴、行业用户以及业内同仁的现场参与,通过精彩的演讲和产品案例的Demo演示,共同为当地...

版权与免责声明:

① 凡本网注明"来源:教育装备采购网"的所有作品,版权均属于教育装备采购网,未经本网授权不得转载、摘编或利用其它方式使用。已获本网授权的作品,应在授权范围内使用,并注明"来源:教育装备采购网"。违者本网将追究相关法律责任。

② 本网凡注明"来源:XXX(非本网)"的作品,均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,且不承担此类作品侵权行为的直接责任及连带责任。如其他媒体、网站或个人从本网下载使用,必须保留本网注明的"稿件来源",并自负版权等法律责任。

③ 如涉及作品内容、版权等问题,请在作品发表之日起两周内与本网联系,否则视为放弃相关权利。

校体购产品