微服务

服务的发布与引用

常见的发布和引用的方式包括:

  • RESTful API / 声明式Restful API
  • XML
  • IDL

声明式Restful API

这种常使用HTTP或者HTTPS协议调用服务,相对来说,性能稍差。

首先服务端如上定义接口并实现接口,随后服务提供者可以使用类似restEasy这样的框架通过servlet的方式发布服务,而服务消费者直接引用定义的接口调用。

除此之外还有一种类似feign的方式,即服务端的发布依赖于springmvc controller,框架只基于客户端模板化http请求调用。这种情况下需接口定义与服务端controller协商一致,这样客户端直接引用接口发起调用即可。

XML

使用私有rpc协议的都会选择xml配置的方式来描述接口,比较高效,例如dubbo、motan等。

同样服务端如上定义接口并实现接口,服务端通过server.xml将文件接口暴露出去。服务消费者则通过client.xml引用需要调用的接口。

但这种方式对业务代码入侵较高,xml配置有变更时候,服务消费者和服务提供者都需要更新。

IDL

IDL是接口描述语言,常用于跨语言之间的调用,最常用的IDL包括Thrift协议以及gRpc协议。例如gRpc协议使用Protobuf来定义接口,写好一个proto文件后,利用语言对应的protoc插件生成对应server端与client端的代码,便可直接使用。

但是如果参数字段非常多,proto文件会显得非常大难以维护。并且如果字段经常需要变更,例如删除字段,PB就无法做到向前兼容。

 

在使用上,大多数人的选择是对外Restful,对内Xml,跨语言IDL。

 

使用注册中心寻址并调用的过程如下:

posted @ 2021-06-03 10:08  KLAPT  阅读(52)  评论(0编辑  收藏  举报