标签:rpc 负载 协议 dubbo 建立连接 protobuf 利用 之间 服务端
常见的发布和引用的方式包括:
这种常使用HTTP或者HTTPS协议调用服务,相对来说,性能稍差。
首先服务端如上定义接口并实现接口,随后服务提供者可以使用类似restEasy这样的框架通过servlet的方式发布服务,而服务消费者直接引用定义的接口调用。
除此之外还有一种类似feign的方式,即服务端的发布依赖于springmvc controller,框架只基于客户端模板化http请求调用。这种情况下需接口定义与服务端controller协商一致,这样客户端直接引用接口发起调用即可。
使用私有rpc协议的都会选择xml配置的方式来描述接口,比较高效,例如dubbo、motan等。
同样服务端如上定义接口并实现接口,服务端通过server.xml将文件接口暴露出去。服务消费者则通过client.xml引用需要调用的接口。
但这种方式对业务代码入侵较高,xml配置有变更时候,服务消费者和服务提供者都需要更新。
IDL是接口描述语言,常用于跨语言之间的调用,最常用的IDL包括Thrift协议以及gRpc协议。例如gRpc协议使用Protobuf来定义接口,写好一个proto文件后,利用语言对应的protoc插件生成对应server端与client端的代码,便可直接使用。
但是如果参数字段非常多,proto文件会显得非常大难以维护。并且如果字段经常需要变更,例如删除字段,PB就无法做到向前兼容。
在使用上,大多数人的选择是对外Restful,对内Xml,跨语言IDL。
标签:rpc 负载 协议 dubbo 建立连接 protobuf 利用 之间 服务端
原文地址:https://www.cnblogs.com/KL2016/p/14844062.html