码迷,mamicode.com
首页 > 其他好文 > 详细

微服务

时间:2021-06-03 18:00:35      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:rpc   负载   协议   dubbo   建立连接   protobuf   利用   之间   服务端   

服务的发布与引用

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

  • 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。

 

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

微服务

标签:rpc   负载   协议   dubbo   建立连接   protobuf   利用   之间   服务端   

原文地址:https://www.cnblogs.com/KL2016/p/14844062.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!