概述

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特点

  1. 支持几乎所有常见语言的实现,包括浏览器中的javascript

  2. 成熟稳定,已经在很多项目中得到验证

  3. 一直在持续稳步更新

  4. 国人开发,有QQ群在线支持,回复比较快速(5分钟之内)

  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应用大致就做三件事:

  1. 复制Hprose文件进项目

  2. 写Hprose服务端

  3. 写Hprose客户端

Hprose服务端要做的事就两件:

  1. new一个HproseHttpServer对象

  2. 用这个对象发布服务,包括函数、方法、对象甚至类

Hprose客户端要做的事就两件:

  1. new一个HproseHttpClient对象

  2. 用这个对象调用服务端发布的各种服务

压测示例

此处我们使用官方自带的HellWorld示例

源代码:https://github.com/hprose/hprose-java

写Hprose服务端

首先创建一个maven web项目,并引入hprose Stub JAR包

  1. <dependencies>

  2.        <!--引入hprose Stub-->

  3.        <dependency>

  4.            <groupId>org.hprose</groupId>

  5.            <artifactId>hprose-java</artifactId>

  6.            <version>2.0.38</version>

  7.        </dependency>

  8.    </dependencies>

在WebRoot/WEB-INFO/Lib目录下引入servlet和websocket的JAR包

创建hello服务类,可以写两个很简单的sayHello方法和add方法

  1. /***

  2. * 服务类

  3. */

  4. public class Hello {

  5.    /***

  6.     * 返回hello+客户端传参

  7.     * @param name

  8.     * @return

  9.     */

  10.    public String sayHello(String name) {

  11.        return "Hello " + name + "!";

  12.    }

  13.    /**

  14.     * 返回两个数字的和

  15.     * @param a

  16.     * @param b

  17.     * @return

  18.     */

  19.    public String add(int a,int b)

  20.    {

  21.        int c=a+b;

  22.        return "结果是:"+c;

  23.    }

  24. }

编写一个服务发布类WebSocketServer绑定WebSocketServer

  1. /***

  2. * 服务发布类

  3. * WebSocket 绑定

  4. * Hprose RPC也可以工作于WebSocket之上,数据以二进制数据的方式在WebSocket上发送和接收。

  5. * Hprose RPC添加了4个字节的头作为请求唯一标识(id),服务器端不需要关心请求唯一标识(id)如何编码,只需要在应答中重复它就可以了。

  6. */

  7. @ServerEndpoint("/wshello")

  8. public class WebSocketServer {

  9.    private HproseWebSocketService service = new HproseWebSocketService();

  10.    public WebSocketServer() {

  11.        //new出服务对象,发布类里面所有的公共方法

  12.        service.add(new Hello());

  13.    }

  14.    @OnOpen

  15.    public void onOpen(Session session, EndpointConfig config) {

  16.        service.setConfig(config);

  17.    }

  18.    @OnMessage

  19.    public void onMessage(ByteBuffer buf, Session session) throws IOException {

  20.        service.handle(buf, session);

  21.    }

  22.    @OnError

  23.    public void onError(Session session, Throwable error) {

  24.        service.handleError(session, error);

  25.    }

  26. }

主要工作都完成了,接着需要在web.xml里注册一下

  1. <?xml version="1.0" encoding="UTF-8"?>

  2. <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">

  3.    <servlet>

  4.        <!--注册服务-->

  5.        <servlet-name>HelloServlet</servlet-name>

  6.        <servlet-class>hprose.server.HproseServlet</servlet-class>

  7.        <init-param>

  8.            <param-name>class</param-name>

  9.            <param-value>hprose.hello.server.Hello</param-value>

  10.        </init-param>

  11.        <init-param>

  12.            <param-name>crossDomain</param-name>

  13.            <param-value>true</param-value>

  14.        </init-param>

  15.        </servlet>

  16.    <!--绑定URL-->

  17.    <servlet-mapping>

  18.        <servlet-name>HelloServlet</servlet-name>

  19.        <url-pattern>/Hello</url-pattern>

  20.    </servlet-mapping>

  21.    <session-config>

  22.        <session-timeout>

  23.            30

  24.        </session-timeout>

  25.    </session-config>

  26.    <welcome-file-list>

  27.        <welcome-file>index.html</welcome-file>

  28.        </welcome-file-list>

  29.    </web-app>

完成后运行tomcat,浏览器自动打开http://localhost:8888/Hello,我们可以看到这个服务已经成功发布了。

写Hprose客户端

接下我们写HelloClient类测试下服务是否ok

  1. /**

  2. * Hprose客户端

  3. */

  4. public class HelloClient {

  5.    public static void main(String[] args) throws IOException {

  6.        //new一个HproseHttpClient对象

  7.        HproseHttpClient client = new HproseHttpClient();

  8.        //使用无参构造器创建的客户端,在进行调用前,需要先调用useService方法初始化服务器地址

  9.        client.useService("http://localhost:8080/Hello");

  10.        //使用invoke方法来动态调用服务。

  11.        String result = (String) client.invoke("sayHello", new Object[] { "Hprose" });

  12.        System.out.println(result);

  13.        result = (String) client.invoke("sayHello", new Object[] { "7DGroup" });

  14.        System.out.println(result);

  15.        System.out.println(client.invoke("add",new Object[]{1,6}));

  16.    }

  17. }

测试成功后,我们把hprose jar包拷贝到apache-jmeter-4.0\lib\ext下

Jmeter压测

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

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

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

至此,我们的一个压测Hprose RPC服务的小例子就完成了。

性能工具之Jmeter压测Hprose RPC服务的更多相关文章

  1. 性能工具之Jmeter压测Thrift RPC服务

    概述 Thrift是一个可互操作和可伸缩服务的框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, ...

  2. 【Java分享客栈】未来迈向高级工程师绕不过的技能:JMeter压测

    前言 因为工作需要,久违的从自己的有道云笔记中去寻找压测相关的内容,翻开之后发现还不错,温故一遍后顺便整理出来分享给大家. 题外话,工作8年多,有道云笔记不知不觉都6G多了,扫一眼下来尽是云烟过往,竟 ...

  3. JMeter接口压测——ServerAgent监控服务端性能指标

    ServerAgent作为一个服务端性能监控插件,结合JMeter自身插件PerfMon可以实现JMeter压测的图形化实时监控,具有良好的实用性.下面讲解一个应用实例 思路: 1. 插件准备 2.打 ...

  4. windows下Jmeter压测端口占用问题(亲测有效)

    windows下Jmeter压测端口占用问题 1 报错信息描述 压测的初期,在设置了 150qps/s 的并发数下压测几分钟后 Jmeter 就出现了如下报错. JAVA.NET.BINDEXCEPT ...

  5. jmeter压测、操作数据库、分布式、 linux下运行的简单介绍

    一.jmeter压测 1.如何压测 常规性能压测:10-15分钟 稳定性测试:一周.2天等 如果想要压测10分钟,勾选永远,勾选调度器,填写600秒.也可以使用固定启动时间. 2.tps.响应时间 ( ...

  6. windows下Jmeter压测端口占用问题

    https://blog.csdn.net/weixin_43757847/article/details/88188091 1 前情提要人脸识别项目中,云平台新增了人脸识别的校验接口.考虑到存在大量 ...

  7. 一文揭秘测试平台中是如何将测试用例一键转化Jmeter压测脚本

    ​    ​接上篇,一键转化将接口测试平台测试用例转化成Jmeter压测脚本思路,这里我首先在java 上面做了一个简单的实验,看看 转化的中间遇到的问题,这里呢,我只是给了一个简单的demo 版本, ...

  8. jmeter压测app

    使用代理的方式,录制app端脚本,之后用jmeter压测就没啥好说的了 1.电脑端谷歌设置本地代理(端口号为8888) 2.jmeter设置HTTP代理服务器(端口号为8888) 3.手机端wifi设 ...

  9. JMeter压测基础(三)——Mysql数据库

    JMeter压测基础(三)——Mysql数据库 环境准备 mysql驱动 JMeter jdbc配置 JMeter jdbc请求 1.下载mysql驱动:mysql-connector-java.ja ...

随机推荐

  1. Docker部署微服务项目

    测试包准备工作 1.spring.io或者ide创建demo工程 spring官网 2.本地demo代码,打包成jar包 使用Dockerfile构建微服务镜像 3.将jar包上传到你的vps lin ...

  2. ES6学习-5 解构赋值(2)对象的解构赋值

    啥也不说,先举个栗子: 1 let { myname, myage } = { myage: 18, myname: "郭郭" }; 2 console.log(myname) / ...

  3. MD5加密以及登录获取设置token

    MD5简介 MD5是不可逆的加密算法,基本上是不可破解的,网上有些破解网站,其实是利用了穷举法,因为MD5生成的串是一样的,他们会将常规的密码生成MD5加密串,保存,然后破解的时候去穷举比对.(应对之 ...

  4. [DB] mysql windows 安装

    参考 mysql安装 https://www.cnblogs.com/zhangkanghui/p/9613844.html navicat for mysql 中文破解版(无需激活码) https: ...

  5. GCC链接时库顺序问题

    GCC或G++在编译链接时,如果命令行中含有库,则要特别注意了.根据<C专家编程>5.3节中的提示,GCC在链接时对命令行时的处理顺序是从左到右.证据是GCC的MAN: -l librar ...

  6. 还可以使用 -c 参数来显示全部内容,并标出不同之处 diff -c test2.txt test1.txt

    二.实例 在test目录下存放了两个文本文件,test1.txt  test2.txt . 比较这两个文件的异同. diff  test1.txt   test2.txt     "5c5& ...

  7. 强哥PHP学习笔记

    1.php的代码,必须放在.php的文件中,php代码必须写在<?php ?>之间. 2.//单行注释 /* 多行注释 */ 3.默认首页index.php index.html inde ...

  8. 2019年又迎来Hi1620,鲲鹏920则是Hi1620系列的正式品牌和型号

    据记者了解,2013年华为就发布了Hi1610,2014年的Hi1612是ARM64位CPU,2016年的Hi1616是首颗支持多路的ARM处理器,2019年又迎来Hi1620,鲲鹏920则是Hi16 ...

  9. ceph总结复习

    一.ceph概念 Ceph是一种为优秀的性能.可靠性和可扩展性而设计的统一的.分布式文件系统.ceph 的统一体现在可以提供文件系统.块存储和对象存储,分布式体现在可以动态扩展. 什么是块存储/对象存 ...

  10. 022.Python模块序列化模块(json,pickle)和math模块

    序列化模块 一  序列化模块 pickle 1.1 基本认识 序列化:把不能够直接存储的数据变成可存储的过程就是序列化 反序列化:把储存的数据拿出来恢复成原来的数据类型就是反序列化 例如,一个文件不可 ...