Code Base on https://github.com/charlescui/CBenchmark
这是我实现的一款性能测试工具,之前在工作中常用LoadRunner之类的工具来完成性能测试,但受限于LR极其昂贵的Lisence以及难以定制的SDK,于是我用C/C++实现了这个工具,并借助Linux系统对线程和进程的良好调度,可以实现极高的并发压力.
使用的用例有待补全,请大家持续关注官方主页或者github项目主页.
----------
http://cuiz.me/cbenchmark/2011/07/cbenchmarkjieshao/
介绍:
CBenchmark—-CharlesCui’s Benchmark
本产品是为了解决性能测试压力生成的问题.
系统|Platform
在对服务端系统进行性能测试时,目前成熟的解决方案是使用windows系统下LoadRunner等系列产品,而无法找到功能强大的Linux系统下的产品。
本程序目前支持Linux系统,并且理论可以实现跨平台编译(作者并没有实验过,但本产品并没有依赖特定系统的库或者函数).
特点|Feature
- 本程序和当前性能测试解决方案相比,
- 可以实现极高的定制化:开放所有API,用户可以基于这些API实现自己的性能测试工具.
- 无限制:本产品完全免费,不会像现有成熟解决方案一样基于并发数,或者基于使用协议的Lisense限制。
- 高性能高并发:可提供比现有产品高出很多的并发能力,本程序使用C语言实现所有的代码。
- 通用性:由于本产品测试用例的业务实现是由客户完成,所以本产品的作用不限于某种测试协议,所以本产品是一个通用的性能测试工具.
- 执行过程可控:测试执行过程中用户可以通过Ctrl+C来控制本产品的执行。
- 特有的测试用例加载模式:对测试用例加载的模式和市面上的性能测试产品都不一样,用户可以将CBenchmark当做第三方库编码进入测试代码,也可以将CBenchmark当做工具,在执行的时候动态加载测试代码以产生压力.
本产品理论支持所有的服务端性能测试。
对于非标准协议的性能测试,我推荐您使用本产品。
安装过程
./configure --prefix=/opt/cbenchmark
make
make install
安装后产生文件
- 本程序内容如下:
- bin/cbenchmark
- include/*.h
TODO
报表
- 目前本产品提供的测试结果有两种:
- 执行完毕后的文字提示
- 执行完毕后的日志
作者在未来会提供报表生成工具,
但不会集成在本产品中,这是为了保证本产品的干净,高效。
并且在没有桌面的linux端使用本产品执行性能测试,
测试结果的显示手段有限,所以我不建议集成在本工具里。
而是最好用其他工具实现,这样也可以完成分布式性能测试的图表结果展现。
使用方法|Usage
请执行bin/cbenchmark -?
[zheng.cuizh@localhost cbenchmark]$ /usr/local/cbenchmark/bin/cbenchmark -?
CharlesCui's Benchmark
help you do performance test nice.
-o ["Shell command"]
-f [Output result path]
-F [Dynamic lib path.]
-n [Each thread iterations times]
-c [Concurrence NUM]
-l [Syslog level]
-g [Syslog name,less than 128 char]
-v [Show -o stdoutput]
-t [Selftest]
-x [Scenario id]
-T [Timmer(seconds)].
-s [Select a scenario from list]
作者|Author
gtalk/gmail zheng.cuizh@gmail.com
用例|Example
./features目录下面是测试插件,目前还没有完善,现在只实现了ice的测试demo.因为我一直用cbenchmark测试私有协议以及一部分ice协议,私有协议的测试demo不方便公开,而ice协议的测试demo完全可以给大家借鉴.
ICE测试
如果大家不了解ice,可以在这里学习一下:http://www.zeroc.com/
demo位于./features/ice下,几乎所有的ice协议测试都可以用这个框架改一改就行.
- ice测试用例的组成
- main.c 该文件为ice测试用例库的入口程序,根据cbenchmark加载测试用例库的约定,该文件实现了一个initialize函数,该函数可以调度测试的执行,比如提供选择要执行的测试场景等功能,可由用户定制.
- main.h 该文件包含了cbenchmark的头文件,以及若干工具文件,同时声明了main.c中的函数定义.
- mos_perf_test.cpp 该文件包含了mos模块ice接口的测试代码,通过将mos_init函数中实现的ice实例:mos传递给pVuser→verb指针,从而可以让真正实现压力请求的函数:mos_getUserStatus,mos_getUserCount得到该对象的引用,以访问checkcast后得到的MOSInterfacePrx对象.注意new的使用.
- mos_perf_test.h 该文件包含了mos_perf_test.cpp实现的ice连接建立/释放函数(mos_init(),mos_end()),以及测试方法(mos_getUserStatus,mos_getUserCount).
关于main.c
pmw->script.init = mos_init;
pmw->script.act = mos_getUserCount;
pmw->script.end = mos_end;
这是测试mos_getUserCount函数的场景.
- 基本的测试思路是:
- mos_init函数实现初始化,比如ice协议就是建立连接,并将代理类放到堆中并将指针传递给pVuser→verb或者它指向的某个结构,
- mos_getUserCount函数实现迭代的测试,也就是在测试过程中,CBenchmark会不断执行该函数已产生业务上的请求,
- mos_end函数实现释放链接操作.
不管怎样的协议的性能测试,思路如出一辙,你只需按照上面的三条完成业务代码的编写,CBenchmark就会帮助你把这个业务逻辑变成高并发高频率的请求,这样会瞬间给服务端带来极大的压力,从而测试服务器的抗压性.
TODO
这个用例是我在测试工作中积累的数十个测试场景里挑选出来的,已经非常的简单了,但要了解cbenchmark的工作原理,还是需要再阅读更多的关于cbenchmark的文档,我会陆续放出.
分享到:
相关推荐
基于java的开发源码-smart-socket 开源的Java AIO框架.zip 基于java的开发源码-smart-socket 开源的Java AIO框架.zip 基于java的开发源码-smart-socket 开源的Java AIO框架.zip 基于java的开发源码-smart-socket ...
实战章节中作者以测试某大型保险公司电话销售系统为例,手把手教会读者如何用jmeter来完成一个实际的性能测试任务。 本书内容丰富、知识点讲解透彻,适合软件测试工程师、测试经理、高等院校相关专业的学生参考...
UDT-C是UDT协议的C语言实现版本,它提供了C语言接口,方便开发者在C程序中集成UDT功能。UDT-C的开源性质意味着开发者可以查看其源代码,理解其工作原理,并根据需要进行定制和优化。对于那些希望在Linux系统上构建高...
【资源说明】 1、该资源包括项目的全部源码,下载可以直接使用! 2、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和...基于Unity开源框架GameFramewrk实现的一款塔防游戏Demo源码+项目说明.zip
OpenPLC是一款面向开源社区的全功能可编程逻辑控制器(PLC)项目,它提供了丰富的资源,适合学习者和专业人士进行研究与开发。这个项目的独特之处在于它的开放性,不仅软件源代码公开,而且硬件设计也完全透明,使得...
2. xUnit.net:xUnit.net是一个由Microsoft的开发人员创建的轻量级测试框架,注重性能和可扩展性。它支持并发测试,允许在单个测试运行中并行执行多个测试,从而提高测试效率。 3. MSTest:MSTest是Microsoft提供的...
“人人快开”(Renren-Fast)是一款基于SpringBoot和Vue.js的开源框架,它为开发者提供了快速构建企业级Web应用的能力。这份《Renren-Fast开源框架开发文档2.0_完整版》是该框架的详尽指南,旨在帮助开发者深入了解...
NaveGo是一个专为低成本惯性测量单元(IMU)和全球定位系统(GPS)组合导航设计的开源框架。它为研究者和学生提供了一个理想的学习平台,便于理解和实践组合导航技术。在现代导航系统中,组合导航是关键的一部分,它...
《C++设计模式--基于Qt4开源跨平台开发框架》一书主要探讨了如何在C++编程中利用设计模式,并结合Qt4框架进行高效的跨平台应用开发。设计模式是软件工程中的重要概念,它们是经过时间和实践验证的解决特定问题的模板...
Jepsen 是开源社区比较公认的分布式数据库的测试框架。Jepsen 验证过程包括 VoltDB、CockroachDB、Galera、MongoDB、etcd 在内的几乎所有的主流分布式数据库 / 系统。
Jeecg-Boot开源框架是基于Java开发的一款高效、便捷的企业级开发框架,它结合了Spring Boot、MyBatis Plus、Vue.js等技术栈,旨在简化企业级应用的开发流程,提高开发效率。1.0至1.1版本的源码升级主要涵盖了框架的...
标题中的“一个开源通用的应用程序框架.rar”表明我们讨论的主题是一个可以用于构建各种应用程序的开源框架,它以.RAR文件格式提供,可能包含了框架的源代码、文档和其他相关资源。这个框架可能是用一种或多种编程...
在这个特定的项目中,一个基于Java的开源游戏服务器框架被实现,利用了几个关键的技术栈,包括Netty、ProtoBuf和Disruptor。这些技术都是为了优化性能、提高效率和简化通信而设计的。 Netty是一个高性能、异步事件...
为了促进5G技术的普及和发展,开源实现成为了一种重要的趋势。其中,5G-CN(5G核心网)、5G-RAN(5G射频接入网络)和5G-UE(5G用户设备)的开源实现尤为重要。 在5G-CN方面,开源实现可以帮助开发者更好地了解和学习...
GSLAM旨在提供一个通用的开源SLAM框架和基准测试,具有以下功能:共享相同的 API,同时保持与不同 SLAM 系统(例如基于特征或直接方法)的兼容性。支持单目、立体、RGB-D 或任何自定义输入类型(SAR、IMU、GPS 等)...
P-unit 是一款强大的开源性能测试工具,它专为开发者和测试工程师设计,旨在帮助他们评估和优化应用程序的性能。这款软件的独特之处在于其多线程支持功能,使得测试案例能够灵活地在单线程和多线程环境中运行,极大...
Go-Kratos是由著名视频分享网站B站(bilibili)开源的一款强大的Go语言微服务框架,它旨在为开发者提供一套完整的微服务解决方案。在深入理解Go-Kratos之前,我们先来了解一下微服务架构的基本概念。微服务架构是一...
好东西一定得分享,自己现阶段需要好好学习一下QT。C++设计模式--基于Qt4开源跨平台开发框架 完整清晰版中文PDF。好东西而且分数不贵!解压密码qt。
c++设计模式--基于Qt4开源跨平台开发框架(源代码)c++设计模式--基于Qt4开源跨平台开发框架(源代码)c++设计模式--基于Qt4开源跨平台开发框架(源代码)c++设计模式--基于Qt4开源跨平台开发框架(源代码)c++设计模式--...
RunnerGo致力于打造成一款全栈式测试平台,采用了较为宽松的Apache-2.0 license开源协议,方便志同道合的朋友一起为开源贡献力量。目前实现了接口测试、场景自动化测试、性能测试等测试能力。