
Devops微服务架构下具有代码级穿透能力的精准测试
微服务是Devops场景下热门的开发框架,在大型项目中被广泛采用。它把一个大型的单个应用程序和服务拆分为数十个的支持微服务,独立部署、互相隔离,通过扩展组件来处理功能瓶颈问题,比传统的应用程序更能有效利用计算资源。微服务之间无需关心对方的模型,它通过事先约定好的接口进行数据流转,使业务可以高效响应市场变化。但微服务一个明显的表象就是随着服务的增多,传统的测试模式受到很大制约,无法有效进行下去,威胁到整体系统质量。所有J2EE代码层白盒采集工具都无法区分覆盖和具体功能的对应关系,只能以后台模式“笼统“的采集一个阶段的总的覆盖,无法满足对于Devops下对于故障定位、深度测试分析以及敏捷发布算法的要求。
星云测试(www.teststars.cc)发布分布式微服务精准测试解决方案,是目前市场上唯一可达到在复杂分布式系统中,跨多个服务器进行代码白盒级分析、实现请求分布式追踪的测试平台。其中产品内的穿透模块,可以支持各种主流微服务通信架构。例如httpclient,springcloud微服务架构、阿里dubbo微服务架构,以及消息队列,将并发访问场景下跨多个服务多组代码逻辑分离并重建追踪出来。实现业务逻辑的代码在开发层面通过微服务离散后,在测试阶段则可以反向复原整个完整代码执行视图。精准测试里面的穿线概念(Threadingtest)增加了第三层含义,即针对的分布式服务的穿透能力。
微服务场景下,一个完整请求会跨多个计算(服务)节点,而对于以节点为剖面的各种测试和监控手段都变得不那么直接和有效。一个请求链路的失效和性能故障等问题,从一个计算节点剖面去分析是很困难的,因为在一个计算节点剖面上的数据是混合型数据,而无法区分这里面的数据来自于那个请求。原始的方法无法将一个调用链路上的所有信息完整的重新刻画出来。业界流行的APM技术可以某种程度实现这种调用链路分析,该项技术主要用于监控,体现的数据是组件级的,而且为了性能考虑还经常抽取样本,无法达到测试要求的代码级的分析。
微服务采用的“分而治之”的策略,而精准测试对于微服务的测试和运营管控上采用的是“概览全局”的策略。精准测试在编译阶段,重新将微服务所有模块视为一个完整项目,统一编译和插装,经过插装后的代码重新部署到原有节点上。在微服务的启动过程中附加上分布式追踪所需要的agent启动,即可完成微服务场景下达到测试用例级的代码全调用路径分析。由于微服务有多个程序模块,星云测试平台支持模块级增量编译模式,即每次编译替换某一个模块就可以生成一个新的版本,而无需将所有微服务模块全新编译。
穿透和分布式追踪的原理,这里重点讲星云测试JavaEE应用服务器agent的能力。agent提供了一个虚拟jsp的技术,通过agent启动的被测应用,附加了一个虚拟jsp,地址类似于http://www.appundertest.com/teststars.jsp。访问这个页面可以用来指本机的用户,一般这个设置和精准测试示波器的登录用户需要一致。设置完成后,对被测应用的请求将附加上一个用户标识的cookie信息,这个信息会在微服务的多层架构中一直携带和穿透。例如从浏览器发起的一个带着用户标识信息的请求,到了应用服务的处理线程中,这个线程执行的所有代码将附加上这个用户信息,如果应用在向后调用其他的节点的服务,则这个用户信息会继续向后传递,直到最后的执行节点。由于每个节点的代码均有精准测试系统插装的代码,会自动的向用户请求发起端的示波器回馈数据,实现整个调用链路上的代码逻辑发送给示波器这个步骤。示波器收到数据后,将动态数据和代码编译阶段的程序静态数据结合起来,即可展示全链路的程序调用路径信息。从另外角度,当微服务系统有多个请求同时并行的时候,每个示波器收到的是自己对应的请求代码的全链路执行情况,其他示波器用户和其他普通用户的数据,不会被收录进来。
上图是一个spring cloud微服务架构下两个节点的调用图。当从第一层入口组件访问后,入口组件向后调用下一层节点,后一层节点的运行线程自动取到了前一层节点的用户信息,同时加入到第二层节点的运行线程控件。这样,通过精准测试示波器(登录用户标识和请求标识一致)就可以收到两个节点的数据,实现多个用户同时访问分布式应用时,不同用户出发的数据自动分离,路由到对应的示波器,最终对应到测试用例。
喜报|星云测试软件入选工信部2024年信息技术应用创新重点推荐解决方案
以创新技术助力航空软件高质量发展——星云测试参加2024年飞机航空电子国际论坛
星云测试入选2023年江苏省专精特新中小企业名单
2023金融业软件测试成果交流会 星云精准测试助力金融业软件测试数字化转型发展和进步
精准测试技术十年发展漫谈(下)
精准测试技术十年发展漫谈(上)
星云测试受邀出席 第二届工控中国大会
星云测试受邀出席 2022中国工业软件大会
星云测试携手飞腾等合作伙伴会于 2022中国金融产业峰会
星云精准测试平台通过了中国电子技术标准化研究院的软件测试工具能力评价
Wings, 展开单元测试的翅膀
测试数字化转型之精准测试与用例引擎的双轮驱动
“软件赋能汽车”下的新一代智能高可靠性精准测试技术
星云精准测试-为金融系统软件保驾护航
2020年中国银行业软件测试成果交流会”在北京召开
星云测试应邀参加第十一届中国国际软件质量工程(iSQE)峰会
【星云测试Wings-企业级单元用例自动编码引擎】 TiD 2020质量竞争力大会专题演讲
【星云精准测试-新一代软件测试技术流的前瞻与落地】TiD 2020质量竞争力大会专题演讲
Wings-面向企业级的单元测试用例自动编码引擎
Wings-企业级单元测试自动编码引擎白皮书最新发布
精准测试白皮书-2020版最新发布
精准测试在商业银行的研究与实践
星云精准测试有力提升金融复杂系统的测试能效
【星云简讯】“星云测试”喜获高新技术企业证书!
疫情之下,精准测试的智能可信模式正在成为中流砥柱
星云精准测试平台远程指导使用流程
星云测试在“软件工程工具标准工作组”承担相关任务
打造银行软件测试成果交流与共享平台——2019年中国银行业软件测试成果交流会综述
星云精准测试对安卓底层驱动代码的测试案例分析
软件世界 · 质量护航 —— 星云测试应邀参加2019年第十届中国国际软件质量工程(iSQE)峰会
第十届中国国际软件质量工程(iSQE)峰会圆满召开
精准测试白皮书V3.0-2019最新版
精准测试,浩瀚代码星空的守护者
“第一届浦发银行国际金融科技创新大赛在沪举行”星云测试勇夺第一名,荣膺白金奖
Devops微服务架构下具有代码级穿透能力的精准测试
星云精准测试之用例魔方
开发者测试(3)-采用精准测试工具对springcloud微服务应用进行穿透测试
开发者测试(2)-采用精准测试工具对J2EE Guns开发框架进行测试
开发者测试-采用精准测试工具对Spring Boot应用进行测试
精准测试的软件产品质量效率变化分析
Wings发布-让单元测试智能全自动生成
星云简讯:向八一建军节致敬
精准测试在复杂金融系统中的应用
星云精准测试在微服务架构中的应用简述
星云测试简介
2017全国大学生软件测试大赛“星云测试杯”华东区决赛 暨软件测试高峰论坛顺利举行
精准测试白皮书
探究软件测试之明珠—精准测试
星云测试成为省级研发中心牵头企业,专项负责工业软件质量精准诊断与分析平台研发
曾玉波:“精准测试”有望成未来10年主流技术
星云测试发布针对开放式Linux操作系统的嵌入式精准测试平台Shell
精准化测试专业平台Paw:专为苹果APP软件测试“填坑”
You can be the ONE--星云测试平台旗下产品由来
Paw--苹果应用可视化精准测试技术浅析
精准测试在智能机器人上的应用
星云礼包大放送
星云测试——开启软件云测试2.0崭新时代
星云测试-掀起企业应用精准测试的浪潮
兆联天下
15问答为专业测试人员揭开“精准测试”的面纱
新品 | 如何开发出一款高质量APP 【内有福利】
星云在线测试-触手可及的移动应用数字化精准测试
星云测试--让软件像普通商品一样放心交易
沧海一声笑,移动应用的CRASH原因我找到! --记最新款数字化测试“星云测试“的使用攻略
软件测试2.0——ThreadingTest数字化企业测试私有云探秘