最近项目待压测的服务端协议使用的是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. Go语言中映射表map的使用

    1 概述 Go语言中的键值对(key->value)集合,称之为映射map.映射map是变长类型,定义时不需要指定长度.映射map是无序的,遍历是的顺序不可期,原因是底层由hash表实现.逻辑结 ...

  2. Kafka跨网络访问设置

    实际场景: kafka应用通过docker进行部署并暴露出不同kafka节点到不同的指定端口: 业务系统通过虚拟机进行部署: docker宿主机与业务系统在同一个局域网: 报错: 业务系统连接kafk ...

  3. leetcode记录-反转整数

    给定一个 32 位有符号整数,将整数中的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 120 输出: 21 注意: 假 ...

  4. Zabbix学习之路(八)之自动化监控网络发现和主动注册

    1.网络发现  分两步走:创建发现规则(rule)和执行的动作(Action)(1)创建发现规则"Configuration"-->"Create discover ...

  5. Nginx入门篇(四)之常用配置解析

    1.Nginx状态信息功能 Nginx的模块当中有一个ngx_http_stub_status_module模块,这个模块主要记录Nginx的基本访问信息,要使用该模块,需要在编译的时候增加http_ ...

  6. Android 学习1

    使用eclipse做为开发IDE, 导包快捷键 在显红的地方按shift+ctrl+o 另外自动补全使用alt+/

  7. itchat个人练习 语音与文本图灵测试例程

    背景介绍 itchat是一个开源的微信个人号接口,使用python调用微信从未如此简单. 使用不到三十行的代码,你就可以完成一个能够处理所有信息的微信机器人. 官方文档参考https://itchat ...

  8. moment.js使用方法总结

    Moment.js是一个轻量级的JavaScript时间库,它方便了日常开发中对时间的操作,提高了开发效率.日常开发中,通常会对时间进行下面这几个操作:比如获取时间,设置时间,格式化时间,比较时间等等 ...

  9. dubbo 微服务

    # spring-dubbo-service 微服务 项目地址:https://github.com/windwant/spring-dubbo-service spring dubbo servic ...

  10. JavaScript里的循环方法之forEach,for-in,for-of

    JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标 ...