Hessian通信协议学习

寵の児 提交于 2019-12-05 19:08:11

###什么是Hessian

  Hessian是由caucho提供的一种开源的远程通讯协议。 采用二进制 RPC 协议,基于 HTTP 传输,服务器端不用另开放防火墙端口。 协议的规范是公开的,可以用于任意语言。 采用客户机/服务器模式(C/S)。 请求程序就是一个客户机,而服务提供程序就是一个服务器。 客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。 在服务器端,进程保持睡眠状态直到调用信息的到达为止。 当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用进程接收答复信息, 获得进程结果,然后调用执行继续进行。

###Hessian协议工作流程图   ***客户端程序请求服务端函数 ***

  1.调用客户端句柄,执行传送参数。

  2.调用本地系统内核发送网络消息。

  3.消息传送到远程主机。

  4.服务器句柄得到消息并取得参数。

  5.执行远程过程。

输入图片说明

***服务端函数返回结果给客户端 ***

  1.执行的过程将结果返回服务器句柄。

  2.服务器句柄返回结果,调用远程系统内核。

  3.消息传回本地主机。

  4.客户句柄由内核接收消息。

  5.客户接收句柄返回的数据。

输入图片说明

###Hessian的优、缺点 优点   1.目前的WEB端基本上都支持hessian,hessian本身就是使用http的传输协议,来保证安全性和稳定性。

  2.通信速度不错。(数据少的时候)。

  3.可以以对象方式接受数据。   

  缺点

  1.报错机制不够完善。

  2.没有事务处理。

  3.PHP和Java之间经常会出现一些问题,如编码,需强制转换字符等。

  4.返回数据量大,总会感觉有延迟的情况。

###Hessian的部分问题 1、是基于什么协议实现的? 基于Binary-RPC协议实现。 2、怎么发起请求? 需通过Hessian本身提供的API来发起请求。 3、怎么 将请求转化为符合协议的格式的? Hessian通过其自定义的串行化机制将请求信息进行序列化,产生二进制流。 4、使用什么 传输协议传输? Hessian基于Http协议进行传输。 5、响应端基于什么机制来接收请求? 响应端根据Hessian提供的API来接收请求。 6、怎么将流还原为传输格式的? Hessian根据其私有的串行化机制来将请求信息进行反序列化,传递给使用者时已是相应的请求信息对象了。 7、处理完毕后怎么回应? 处理完毕后直接返回,hessian将结果对象进行序列化,传输至调用端。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!