当前位置: 首页 > news >正文

网站络全网关键词搜索排行

网站络,全网关键词搜索排行,天气预报权威发布,自适应主题 wordpress为什么学习Hessian RPC#xff1f; 存粹的RPC#xff0c;只解决PRC的四个核心问题#xff08;1.网络通信2.协议 3.序列化 4.代理#xff09;Java写的HessianRPC落伍了#xff0c;但是它的序列化方式还保存着#xff0c;被Dubbo(Hessian Lite)使用。 被落伍#xff0c;只…为什么学习Hessian RPC 存粹的RPC只解决PRC的四个核心问题1.网络通信2.协议 3.序列化 4.代理Java写的HessianRPC落伍了但是它的序列化方式还保存着被Dubbo(Hessian Lite)使用。 被落伍只是因为Hessian RPC出的比较早当时没有注册中心熔断限流等。所以当我们学习PRC时最好学一个简单的存粹的没有其他的额外功能。 Hessian 的概念 Hession 是Resin服务器的伴生产品。基于Java编程语言设计的RPC框架只支持Java编程语言使用现在新出的gRPC Thrift支持多语言。Hessian的序列化是二进制的。 Hessian设计思想 Hessian使用的resin服务器类似于Tomcat使用的是HTTP协议由于使用的是JDK做代理所以必须要用接口定义调用类。对象的数据类型必须要实现Serliazble。服务的发布需要使用HessanServlet进行配置在web.xml进行配置。 那么如何进行调用配置的服务客户端进行代理HessianProxyFactory做代理服务。 RPC的开发 引入依赖 dependenciesdependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.13.1/versionscopetest/scope/dependencydependencygroupIdjavax.servlet/groupIdartifactIdjavax.servlet-api/artifactIdversion3.1.0/versionscopeprovided/scope/dependencydependencygroupIdorg.slf4j/groupIdartifactIdslf4j-api/artifactIdversion1.7.32/version/dependencydependencygroupIdch.qos.logback/groupIdartifactIdlogback-classic/artifactIdversion1.2.9/version/dependencydependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactIdversion1.18.22/version/dependencydependencygroupIdcom.caucho/groupIdartifactIdhessian/artifactIdversion4.0.38/version/dependency /dependencies开发服务端 1. 开发Service 2. DAO --- Mybaits 注意一定要定义Service的接口自定义的数据类型实现Serliazliable模拟一下登录功能 实体类 Data ToString NoArgsConstructor AllArgsConstructor public class User implements Serializable {private static final long serialVersionUID 1L;private String name;private String password; }Service public interface UserService {public boolean login(String username,String password);public void register(User user);}ServrceImpl Slf4j public class UserServiceImpl implements UserService {Overridepublic boolean login(String username, String password) {log.debug(login method invoke name {} password {},username,password);return false;}Overridepublic void register(User user) {log.debug(register method invoke user {},user);} }配置web.xml servletservlet-nameuserServiceRPC/servlet-nameservlet-classcom.caucho.hessian.server.HessianServlet/servlet-classinit-paramparam-namehome-api/param-nameparam-valuecom.liu.service.UserService/param-value/init-paraminit-paramparam-namehome-class/param-nameparam-valuecom.liu.service.UserServiceImpl/param-value/init-param/servletservlet-mappingservlet-nameuserServiceRPC/servlet-nameurl-pattern/userServiceRPC/url-pattern/servlet-mapping客户端开发 Slf4j public class HessianRPCClient {public static void main(String[] args) throws MalformedURLException {// TODOHessianProxyFactory factory new HessianProxyFactory();String urlName http://localhost:8080/rpc_hessian/userServiceRPC;UserService userService (UserService) factory.create(UserService.class, urlName);boolean login userService.login(liu, 123456);log.debug(userService value is {},login);} }HessianRPC核心源码分析 1. HessianRPC client创建代理的方式 JDK Proxy.newProxyInstance()public Object create(Class? api, URL url, ClassLoader loader){if (api null)throw new NullPointerException(api must not be null for HessianProxyFactory.create());InvocationHandler handler null;handler new HessianProxy(url, this, api);return Proxy.newProxyInstance(loader,new Class[] { api,HessianRemoteObject.class },handler);}2. 代理中 通过网络 Http请求 连接 远端RPC服务通过流 数据写出去了。HessianProxy#invoke() 1.通过 URLConnection 进行网络连接 2.解析协议 传递数据Hessian序列化 前面说了Hessian已经落伍了但他的序列化方式还保留着我们看看怎么使用的。 // 1. 序列化OutputStream outputStream new FileOutputStream(D:\\StudyCodes\\rpc_lession\\rpc_hessian\\test);Hessian2Output hessian2Output new Hessian2Output(outputStream);hessian2Output.writeObject(new User(liu, 123456));hessian2Output.flush();outputStream.close();// 2. 反序列化InputStream inputStream new FileInputStream(D:\\StudyCodes\\rpc_lession\\rpc_hessian\\test);Hessian2Input hessian2Input new Hessian2Input(inputStream);User user (User) hessian2Input.readObject();System.out.println(user);inputStream.close();log.info(user: {}, user);
http://www.dnsts.com.cn/news/52480.html

相关文章:

  • 商丘哪里做网站比较好怎样做农产品交易平台网站
  • 邢台建设网站公司wordpress网站布局
  • 刚备案的域名如何做网站柒比贰wordpress主题
  • 怎么做 代刷网站建设云企业服务平台
  • wordpress建站 网盘视频教程重庆高端网站建设公司
  • 南京网站开发长春手机网站
  • 爱网站搭建免费做团购网站的软件有哪些
  • 临沂网站建设推广重庆网站设计开发培训学校
  • 免费做网站软件2003化妆品网站的搭建
  • 黄页推广服务seo优化排名营销
  • 高端手机网站定制政务信息系统网站建设规范
  • 展示型网站建哪个兄弟给个地址呀
  • 怎么做网站省钱wordpress 主题 小说
  • 1元云购网站怎样建设wordpress手机端在哪里调
  • 郑州汽车网站建设哪家好comment_form wordpress
  • 黄石网站设计制作公司乡村建设相关网站
  • 都芳漆中文网站建设湘潭做网站
  • 自助建站平台有哪些商标与logo的区别
  • 中国搜索引擎市场份额北京seo网站推广费用
  • 网站建设研究课题软件制作器手机版下载
  • 深圳大型网站建设服务公司上海最新新闻
  • 制作网站系统大棚网站怎么做
  • 关于征求网站建设的通知网站建设的频道是什么
  • 北京网站平台建设公司做卷皮网类似网站
  • 滕州网站建设制作dux2.0支持Wordpress
  • 有没有做q版头像的网站什么是网站版式
  • 个人网站收款问题个人域名备案完成了 可以改网站内容吗
  • 网站附件做外链辽宁企业信息公示系统
  • 网站建设公司排名前十html代码表示什么
  • windows server 2008 网站配置郑州网站建设学校