性能工具之Jmeter压测Hprose RPC服务
概述
Hprose(High Performance Remote Object Service Engine),国人开发的一个远程方法调用的开源框架。它是一个先进的轻量级的跨语言跨平台面向对象的高性能远程动态通讯中间件,它支持众多语言,例如nodeJs, C++,.NET,Java,Delphi,Objective-C,ActionScript,JavaScript,ASP,PHP,Python, Ruby,Perl等。
什么是RPC?
RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。 其实简单的说,就是象调用本地的类的方法样来调用服务器端的方法实现。
具体参考以下文章:
Hprose特点
支持几乎所有常见语言的实现,包括浏览器中的javascript
成熟稳定,已经在很多项目中得到验证
一直在持续稳步更新
国人开发,有QQ群在线支持,回复比较快速(5分钟之内)
和实体能保持很好的兼容性,实体工作量较小
Hprose服务端
Hprose 2.0 for Java 支持多种底层网络协议绑定的服务器,比如:HTTP 服务器,TCP 服务器和 WebSocket 服务器。 HTTP 服务器支持在 HTTP、HTTPS 协议上通讯。 TCP 服务器支持在 TCP 协议上通讯,并且支持全双工和半双工两种模式。 WebSocket 服务器支持在 ws、wss 协议上通讯。
Hprose客户端
Hprose 2.0 for Java 支持两种底层网络协议绑定的客户端:HTTP 客户端 和 TCP 客户端。 其中 HTTP 客户端支持跟 HTTP、HTTPS 绑定的 Hprose 服务器通讯。 TCP 客户端支持跟 TCP 绑定的 Hprose 服务器通讯,并且支持全双工和半双工两种模式。 尽管支持这两种不同的底层网络协议,但除了在对涉及到底层网络协议的参数设置上有所不同以外,其它的用法都完全相同。
官网地址: http://hprose.com/
实现逻辑
Hprose应用大致就做三件事:
复制Hprose文件进项目
写Hprose服务端
写Hprose客户端
Hprose服务端要做的事就两件:
new一个HproseHttpServer对象
用这个对象发布服务,包括函数、方法、对象甚至类
Hprose客户端要做的事就两件:
new一个HproseHttpClient对象
用这个对象调用服务端发布的各种服务
压测示例
此处我们使用官方自带的HellWorld示例
源代码:https://github.com/hprose/hprose-java
写Hprose服务端
首先创建一个maven web项目,并引入hprose Stub JAR包
<dependencies><!--引入hprose Stub--><dependency><groupId>org.hprose</groupId><artifactId>hprose-java</artifactId><version>2.0.38</version></dependency></dependencies>
在WebRoot/WEB-INFO/Lib目录下引入servlet和websocket的JAR包

创建hello服务类,可以写两个很简单的sayHello方法和add方法
/**** 服务类*/public class Hello {/**** 返回hello+客户端传参* @param name* @return*/public String sayHello(String name) {return "Hello " + name + "!";}/*** 返回两个数字的和* @param a* @param b* @return*/public String add(int a,int b){int c=a+b;return "结果是:"+c;}}
编写一个服务发布类WebSocketServer绑定WebSocketServer
/**** 服务发布类* WebSocket 绑定* Hprose RPC也可以工作于WebSocket之上,数据以二进制数据的方式在WebSocket上发送和接收。* Hprose RPC添加了4个字节的头作为请求唯一标识(id),服务器端不需要关心请求唯一标识(id)如何编码,只需要在应答中重复它就可以了。*/@ServerEndpoint("/wshello")public class WebSocketServer {private HproseWebSocketService service = new HproseWebSocketService();public WebSocketServer() {//new出服务对象,发布类里面所有的公共方法service.add(new Hello());}@OnOpenpublic void onOpen(Session session, EndpointConfig config) {service.setConfig(config);}@OnMessagepublic void onMessage(ByteBuffer buf, Session session) throws IOException {service.handle(buf, session);}@OnErrorpublic void onError(Session session, Throwable error) {service.handleError(session, error);}}
主要工作都完成了,接着需要在web.xml里注册一下
<?xml version="1.0" encoding="UTF-8"?><web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"><servlet><!--注册服务--><servlet-name>HelloServlet</servlet-name><servlet-class>hprose.server.HproseServlet</servlet-class><init-param><param-name>class</param-name><param-value>hprose.hello.server.Hello</param-value></init-param><init-param><param-name>crossDomain</param-name><param-value>true</param-value></init-param></servlet><!--绑定URL--><servlet-mapping><servlet-name>HelloServlet</servlet-name><url-pattern>/Hello</url-pattern></servlet-mapping><session-config><session-timeout>30</session-timeout></session-config><welcome-file-list><welcome-file>index.html</welcome-file></welcome-file-list></web-app>
完成后运行tomcat,浏览器自动打开http://localhost:8888/Hello,我们可以看到这个服务已经成功发布了。

写Hprose客户端
接下我们写HelloClient类测试下服务是否ok
/*** Hprose客户端*/public class HelloClient {public static void main(String[] args) throws IOException {//new一个HproseHttpClient对象HproseHttpClient client = new HproseHttpClient();//使用无参构造器创建的客户端,在进行调用前,需要先调用useService方法初始化服务器地址client.useService("http://localhost:8080/Hello");//使用invoke方法来动态调用服务。String result = (String) client.invoke("sayHello", new Object[] { "Hprose" });System.out.println(result);result = (String) client.invoke("sayHello", new Object[] { "7DGroup" });System.out.println(result);System.out.println(client.invoke("add",new Object[]{1,6}));}}
测试成功后,我们把hprose jar包拷贝到apache-jmeter-4.0\lib\ext下

Jmeter压测
打开Jmeter,设置线程组为5个

新建一个BeanShell Sampler及察看结果树,拷贝HelloClient代码到BeanShell script内,使用随机数函数对请求的数字进行参数化

运行并查看Jmeter控制台输出结果

至此,我们的一个压测Hprose RPC服务的小例子就完成了。
性能工具之Jmeter压测Hprose RPC服务的更多相关文章
- 性能工具之Jmeter压测Thrift RPC服务
概述 Thrift是一个可互操作和可伸缩服务的框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, ...
- 【Java分享客栈】未来迈向高级工程师绕不过的技能:JMeter压测
前言 因为工作需要,久违的从自己的有道云笔记中去寻找压测相关的内容,翻开之后发现还不错,温故一遍后顺便整理出来分享给大家. 题外话,工作8年多,有道云笔记不知不觉都6G多了,扫一眼下来尽是云烟过往,竟 ...
- JMeter接口压测——ServerAgent监控服务端性能指标
ServerAgent作为一个服务端性能监控插件,结合JMeter自身插件PerfMon可以实现JMeter压测的图形化实时监控,具有良好的实用性.下面讲解一个应用实例 思路: 1. 插件准备 2.打 ...
- windows下Jmeter压测端口占用问题(亲测有效)
windows下Jmeter压测端口占用问题 1 报错信息描述 压测的初期,在设置了 150qps/s 的并发数下压测几分钟后 Jmeter 就出现了如下报错. JAVA.NET.BINDEXCEPT ...
- jmeter压测、操作数据库、分布式、 linux下运行的简单介绍
一.jmeter压测 1.如何压测 常规性能压测:10-15分钟 稳定性测试:一周.2天等 如果想要压测10分钟,勾选永远,勾选调度器,填写600秒.也可以使用固定启动时间. 2.tps.响应时间 ( ...
- windows下Jmeter压测端口占用问题
https://blog.csdn.net/weixin_43757847/article/details/88188091 1 前情提要人脸识别项目中,云平台新增了人脸识别的校验接口.考虑到存在大量 ...
- 一文揭秘测试平台中是如何将测试用例一键转化Jmeter压测脚本
接上篇,一键转化将接口测试平台测试用例转化成Jmeter压测脚本思路,这里我首先在java 上面做了一个简单的实验,看看 转化的中间遇到的问题,这里呢,我只是给了一个简单的demo 版本, ...
- jmeter压测app
使用代理的方式,录制app端脚本,之后用jmeter压测就没啥好说的了 1.电脑端谷歌设置本地代理(端口号为8888) 2.jmeter设置HTTP代理服务器(端口号为8888) 3.手机端wifi设 ...
- JMeter压测基础(三)——Mysql数据库
JMeter压测基础(三)——Mysql数据库 环境准备 mysql驱动 JMeter jdbc配置 JMeter jdbc请求 1.下载mysql驱动:mysql-connector-java.ja ...
随机推荐
- 判断标准I/O的缓冲区类型
#include <stdio.h> void pr_stdio(const char *, FILE *); int main() { FILE *fp; fputs("ent ...
- Envoy:离群点检测 outlier detection
outlier detection 在异常检测领域中,常常需要决定新观察的点是否属于与现有观察点相同的分布(则它称为inlier),或者被认为是不同的(称为outlier).离群是异常的数据,但是不一 ...
- wps中新罗马字体如何设置Times New Roman
word wps中新罗马字体如何设置Times New Roman ### WPS字体自带 Times New Roman ###
- 使用 parted 命令可以查看系统采用什么类型的分区表 gpt/mbr/msdos/ext/ext/ext2/ext3/ext4
Linux磁盘表示方式 Linux以字母标识磁盘的个数 a:第一块 b:第二块 Linux用数字标识分区:1-4标识主分区或扩展分区 逻辑分区从5开始 例如:sda.sda1.sda2 低级格式化 ...
- Kubernetes-3.3:ETCD集群搭建及使用(https认证+数据备份恢复)
etcd集群搭建 环境介绍 基于CentOS Linux release 7.9.2009 (Core) ip hostname role 172.17.0.4 cd782d0a790b etcd1 ...
- 最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析
最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析 最小生成树,老生常谈了,生活中也总会有各种各样的问题,在这里,我来带你一起分析一下这个算法的思路与实现的方式吧~~ 在考研中呢 ...
- unity UGUI填坑 之 HorizontalLayoutGroup 和 ContentSizeFitter配合使用
今天在项目中遇到一个问题,我们的ui过来找我,问为什么Content里的Item显示的不完全 花了半个小时看了一下,发现个小小的坑,记录一下 这些属性是用来实现,Content下的Item的偏移和间隔 ...
- springboot对mybatis的整合
1. 导入依赖 首先新建一个springboot项目,勾选组件时勾选Spring Web.JDBC API.MySQL Driver pom.xml配置文件导入依赖 <!--mybatis-sp ...
- .Net Redis实战——实现文章投票并排序
本系列文章为学习Redis实战一书记录的随笔. 软件和环境版本:Redis:5.0.7 .Net 5.0 文中不会对Redis基础概念做过多介绍. Redis数据类型和命令可在菜鸟教程学习:http ...
- [leetcode] 33. 搜索旋转排序数组(Java)
33. 搜索旋转排序数组 说实话这题我连题都没有看懂....真是醉了 二分,没意思,直接交了- - https://www.jiuzhang.com/solutions/search-in-rotat ...