最近项目待压测的服务端协议使用的是java的Netty框架开发,而传输的业务数据使用了google protobuf进行序列化,然后通过tcp数据流与客户端通讯。这一次的压测脚本决定使用LR的java脚本来写,一直以来LR中使用java写脚本使用的并不多,但现在公司项目主要使用的是java语言,所以也打算保持技术的一致性,测试相关的也尽量使用java了。

  找了些LR下写的java压测脚本的例子,然后自己使用基本的java io API实现了Demo,看起来貌似并不复杂,然而与服务端进行调试时并没有调试通,服务端解析客户端发送过的数据时失败,未识别客户端的数据。可以确定的是服务端的功能是正常的,并且服务端与android客户端是已经调试通过的,不过andriod客户端也使用了Netty框架来处理协议相关的,反复检查了使用基本的java io实现的客户端demo代码后确定是没有问题的,那么为啥就不通呢?

  首先想到的是了解下netty相关的原理,netty框架大概是如何实现的,使用的是什么底层API等?不过这都需要一点时间的,直接发代码给服务端开发人员询问下遇到的问题,开发人员虽然没有马上找出问题的原因,不过猜测可能是根tcp数据传输过程中的粘包/拆包有关,服务端netty会进行粘包处理。。。 大概知道了可能的原因后,花了些时间看了下netty相关的教程及博客对于粘包相关的,netty服务端对于protobuf数据使用了ProtobufVarint32FrameDecoder方式进行解码,也即是通过头部字段来获得整个传输业务数据的长度,然后接收对应字节的数据流进行解析,而且头部使用的是一种不同于java的int类型的一种特殊类型varint,具体相关的数据编解码可以查阅相关博客教程。因为相关的编解码处理都是有netty框架来完成的,业务代码只需要指定一种编解码方式即可,所以这里隐藏的编解码处理在一开始如果不熟悉netty框架的话是未知的,导致按常规的处理流程就导致错误了, 那么很显然遇到服务端解析失败的原因是因为客户端发送的数据没有进行相关的编码处理,而服务端正常进行了解码处理导致的问题。

  需要解决的问题即是按netty的ProtobufVarint32FrameDecoder编码方式对发送的数据做同样的处理,通过原理自己写编解码的方法固然是可以的,如果考虑其通用性应该也是稍有点麻烦的,有开发同事提供了更好的办法,那就是google protobuf的jar包中已经提供了相对的API来处理这种编解码,使用之调试便成功了。

  之后将协议相关的封装在java的jar中,提供给LR进行调用,其间还遇到一些LR和java包版本相关的问题,由于LR11只支持到java6,版本已经比较低了,建议以后写LR调用的java类时,java代码在LR相同的机器上使用相同版本的java进行编写调试打包,这样可以避免很多版本方面的问题。基于本次脚本开发调试过程中遇到的问题,总结一些注意事项:

  1)LR的java脚本中调用的jar包导入时:除了自定义类方法所在的jar包外,该jar包依赖的jar包也同样需要导入到LR中,如本次调用的jar用到了google protobuf,那google的protobuf-java-2.4.1.jar包也同样需要导入到LR中

  2)mac机器上写的java代码源文件拷贝到windows上后编译时会有编码问题 (导致java错误:需要为class interface或enum),原因是windows奇葩的BOM文本编码导致的。在windows上新建文件然后拷贝代码的方式可以解决。

  3)使用maven编译时竟然遇到由于机器开启了VPNFQ,有很多的需要下载的相关插件依赖包等下载过程中卡不一直不动了,关掉FQ的VPN才正常的。

  4)本次LR java压力测试脚本开发环境的配套版本:

    操作系统: windows8 X64
    loadrunner: LR11.00.0.0
    maven: 3.0.5
    java:1.6.0_45
    google protobuf: 2.4.1

LR之Java Vuser II的更多相关文章

  1. LR之Java Vuser

    虽然LR对C有较好的支持,但有时使用Java Vuser会更方便,以下描述通过LR来编写Java脚本以及调用jar包的基本步骤. 1.安装配置java环境  LR的java vuser脚本的执行依赖于 ...

  2. LR接口测试---Java Vuser之增删改查

    import lrapi.lr; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prepared ...

  3. LR接口测试---Java Vuser之jdbc查询(调试前)

    在eclipse下编写好的代码: import lrapi.lr; import java.sql.Connection; import java.sql.DriverManager; import ...

  4. loadrunner之Java Vuser协议脚本编写

    步骤:1.根据自己使用的lr版面选择jdk 1)LR11   1.6   32位 2)LR12   1.7   32位 2.安装好jdk,并搭建java环境变量,安装好java代码编写工具 3.在sr ...

  5. loadrunner11中java vuser引用jar包

    1.创建工程,新建类,HelloWorld.java,代码如下: package com.liuke; public class HelloWorld { public String getHello ...

  6. 【原创】LoadRunner Java Vuser开发环境配置指南

    1 编写目的 本文主要介绍Java运行环境的配置,同时通过编写HelloWorld程序,讲解在LoadRunner下如何开发简单的Java Vuser脚本.关于Java语言的深入学习,大家可以参考其他 ...

  7. LR使用Java User协议环境报错Please add the <JDK>\bin to the path and try again

    看标题报错信息就知道,这是java编译及运行环境配置问题,运行LR脚本时,LR代理找不到java的JDK环境,当然,可能有人会遇到说,我在cmd窗口javac 环境是没问题的呀,是的,这就要看你的jd ...

  8. LoadRunner JAVA Vuser接口测试

    注:JDK只支持1.6 1.创建工程Test2.写个经典的HelloWorld类.3.Runas--->Java Application运行下4.将工程下的整个com包拷贝到loadrunner ...

  9. LoadRunner系列之—-03 用Java Vuser协议编写接口测试脚本

    待测试接口用java语言实现,且项目中调用该接口需要用专门的jar包.这种情况可以用Java Vuser协议实现接口调用脚本,类似java代码. 代码样例如下: /* * LoadRunner Jav ...

随机推荐

  1. SQL注入总结篇

    分类SQL注入的攻击方式根据应用程序处理数据库返回内容的不同,可以分为可显注入.报错注入和盲注. 可显注入攻击者可以直接在当前界面内容中获取想要获得的内容. 报错注入数据库查询返回结果并没有在页面中显 ...

  2. C语言实现文件复制功能(包括文本文件和二进制文件)

    文件的复制是常用的功能,要求写一段代码,让用户输入要复制的文件以及新建的文件,然后对文件进行复制.能够复制的文件包括文本文件和二进制文件,你可以复制1G的电影,也可以复制1Byte的txt文档. 实现 ...

  3. django中models的filter过滤方法

    __gt     大于__gte   大于等于 __lt      小于 __lte    小于等于 __in     存在于一个list范围内 __startswith    以...开头 __is ...

  4. Oracle入门第二天(上)——基本查询SQL

    一.SQL概述 起源于标准不再赘述,主要分为DDL,DML,DCL 相关介绍,参考MySQL章节:http://www.cnblogs.com/jiangbei/p/6696202.html 二.基本 ...

  5. 20155216 2016-2017-2 《Java程序设计》第二周学习总结

    教材学习内容总结 类型 short占2字节 int占4字节 long占8字节 byte占1字节,可表示-128~127的整数 char占2字节 boolean不考虑占字节 float占4字节 doub ...

  6. C语言复习20170728

    C语言复习20170728 键盘输入和屏幕输出 字符常量:把字符放在一对单引号内,适用于多数可打印字符. 转义字符: 以反斜线()开头,也是放在一对单引号内,适用于控制字符. .\t,是水平制表符,相 ...

  7. sort与qsort的异同

    主要内容: 1.qsort的用法 2.sort的用法 3.qsort和sort的区别 qsort的用法: 原 型: void qsort(void *base, int nelem, int widt ...

  8. ConfigurationManager 读写AppSettings键值对

    using System; using System.Configuration; namespace ConsoleApplication1 { class Program { static voi ...

  9. AWVS11提取规则文件

    在这里给大家分享一个获取AWVS规则文件的思路.  目前我提取的是17年4月份的扫描规则.   后面如果规则更新,可以自行提取 官网:   https://www.acunetix.com/vulne ...

  10. 了解ASP.NET Core 依赖注入,看这篇就够了

    DI在.NET Core里面被提到了一个非常重要的位置, 这篇文章主要再给大家普及一下关于依赖注入的概念,身边有工作六七年的同事还个东西搞不清楚.另外再介绍一下.NET  Core的DI实现以及对实例 ...