Test Load Balancer 测试均衡负载

简介:

什么是Test Load Balancer ?

  Test Load Balancer 测试分发工具,它能把所有的测试按照某个策略(数量、时间)均衡分布到不同的计算机上运行。

  问题域?

  一个典型的问题,当软件开发团队在做CI(持续集成)时,必须让CI的构建时间保持在一个合理的时间,比如10分钟为一个上线,但是由于需求的不断增多测试的数量也随之增加,花费在运行这些测试的时间越来越多,影响到了整个交付团队的进度。为了尽可能的缩短交付周期时间,减少测试的运行时间,一个行之有效的方法就是让测试并行执行。

  Test Load Balancer 如何工作 ?

  TLB(Test Load Balancer)有两个比较重要的概念:

  server:存储,查询测试数据(测试时间、测试结果等)

  balancer:测试分支,指定测试套件,设置server的url等

  Balancer与CI或者与某种测试框架一起工作,Server只是一个数据交互中心,Balancer需要测试的数据需要和Server通信。

  如何使用?

  TLB必须结合构建工具使用,我们以TLB自带的例子为例。

  examples/ant_junit

  这个例子使用shell写的运行脚本,我在windows上做的,先把它的脚本改改。

  把run_balancer.sh和上级目录的recipe.sh在powershell脚本里面合并。

$env:TLB_JOB_NAME='ant_junit'
$env:TLB_TOTAL_PARTITIONS='2'
$env:TEST_TASK='ant test.balanced'

Function StartServer() {
    cd ..\..\server
    .\server.bat start
    cd ..\examples\ant_junit
}

Function RunTest() {
    $env:TLB_DATA_DIR='.\demo_tlb_store'
    $env:TLB_OUT_FILE-".\tlb_balancer.out"
    $env:TLB_ERR_FILE='.\tlb_balancer.err'
    $env:TLB_BASE_URL='http://localhost:7019'
    $env:TLB_JOB_VERSION='1.0.0'

    for($i=1; $i -le $env:TLB_TOTAL_PARTITIONS; $i++) {
        $env:TLB_PARTITION_NUMBER='$i'
        $env:TLB_BALANCER_PORT='300$i'
        iex $TEST_TASK
    }
}

Function StopServer() {
    cd ..\..\server
    .\server.bat stop
    cd ..\examples\ant_junit
}

Function Runner() {
    StartServer
    RunTest
    StopServer
}

Runner

  TLB所有的设置依赖环境变量, TLB_TOTAL_PARTITIONS指定所有的测试分成多少份,TLB_BASE_URL指定TLB Server的地址,TLB_PARTITION_NUMBER当前node执行那一份测试,TLB_BALANCER_PORT指定node的端口。

  StartServer启动TLB服务器,会开启一个cmd窗口,关闭的时候调用脚本关闭这个窗口就可以关闭TLB 服务器。

  RunTest 运行测试,在每个node都必须配置TLB_PARTITION_NUMBER和TLB_BALANCER_PORT.

  StopServer 关闭TLB Server。

  Runner 脚本入口函数。

  这里的脚本是把TLB Server 和 Balancer写在一起的,只为show一下TLB如何使用,如果要在不同node运行,必须把它分成server和balancer两部分脚本。server只需要 StartServer 和StopServer函数,而node只需要RunTest函数,去掉for循环,指定具体的TLB_PATTITION_NUMBER和PORT就可以了。

  TLB不足?

  TLB虽然可以实现测试分发,但是如果不结合CI工具的话,就必须手动的去运行每个node,而且在server也不能监控和收集每个node的运行结果。








====================================分割线================================



最新内容请见作者的GitHub页:http://qaseven.github.io/

相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
3月前
|
JavaScript 前端开发 Devops
负载测试的最佳实践
负载测试的最佳实践
|
4月前
|
监控 前端开发 JavaScript
如何测试前端代码? 知道 BDD, TDD, Unit Test 么? 知道怎么测试你的前端工程么(mocha, sinon, jasmin, qUnit..)?
如何测试前端代码? 知道 BDD, TDD, Unit Test 么? 知道怎么测试你的前端工程么(mocha, sinon, jasmin, qUnit..)?
74 0
|
4月前
|
监控 前端开发 JavaScript
如何测试前端代码? 知道 BDD, TDD, Unit Test 么? 知道怎么测试你的前端工程么(mocha, sinon, jasmin, qUnit..)?
如何测试前端代码? 知道 BDD, TDD, Unit Test 么? 知道怎么测试你的前端工程么(mocha, sinon, jasmin, qUnit..)?
40 0
|
3月前
|
测试技术 Shell Android开发
随机测试 Monkey Test
随机测试 Monkey Test
|
3月前
|
测试技术 应用服务中间件 Apache
负载测试
负载测试
|
3月前
|
测试技术 网络安全
负载测试二
负载测试二
负载测试二
|
3月前
|
测试技术 应用服务中间件 网络安全
负载测试介绍一
负载测试介绍一
|
3月前
|
缓存
pytest 运行测试函数报错的解决办法 TypeError: calling <function xxx> returned None, not a test
pytest 运行测试函数报错的解决办法 TypeError: calling <function xxx> returned None, not a test
96 0
|
3月前
|
机器学习/深度学习 Shell 开发工具
利用 test命令的测试功能
【1月更文挑战第4天】利用 test命令的测试功能。
45 4
|
6月前
|
安全 测试技术
什么是软件测试领域的 Smoke Test
什么是软件测试领域的 Smoke Test
100 0