因为涉及到真实产品,把一些实现的细节屏蔽了。
系统架构简化后如下图:
测试客户端只要能发送大量上传文件的http请求即可。
1、先建立一个conf.properties文件,主要内容如下
threadCount=2 //客户端线程数
requestPerThread=1 //每个线程请求数
filePath=/home/qatest/uploadtest/files/ //存放需上传文件的文件夹,已按照实际统计数据预生成很多文件
requestUrl=http://insp92.space.163.org:8291/fs/formUpload //请求url
2、建立ParseProp.java,其功能是从conf.properties获取参数
为了篇幅考虑,只保留获取“filePath”的代码,其他略
3、建立HttpUploadPerfTest.java,代码结构如下:
最后谈几点经验:
1、简单上传服务需要上传文件,文件如何生成?开始的方案是先准备少量几个文件,在构造http请求的时候往文件最后append当前时间戳,使文件内容不同。这种方式,由于文件很大,每次读文件导致垃圾很多,cpu都花在垃圾收集上,使客户端性能比服务端差,最后取消这种方式。
2、自己编程的方式vs用测试工具,一般来说“自己编程的方式”客户端性能好。
3、每次请求一定要详细记录该请求的所有信息,比如线程id、请求id、用户名、文件名、成功信息、错误信息等,以方便事后分析。因为性能测试运行很快,等发现问题的时候已经无法还原现场了。所以记录足够的信息非常重要,不仅是客户端,服务端也需要记录足够信息。而且,如果没有足够信息,也无法进行精确的统计。