Dubbo--微服务框架

一、Dubbo简介
Dubbo是一个分布式服务框架,支持高性能远程调用,提供SOA服务治理解决方案。Ddubbo各个分层都是很多扩展,比如注册中心有redis、zookeeper选项,序列化有java序列化等,当然还有很多,这里就不一一介绍了。

二、核心部分

2.1、远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。

2.2、集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。

2.3、自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以减少机器。

三、作用

3.1、透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。

3.2、软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。

3.3、 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

四、使用

4.1、当我们在多个Tomcat部署不同的系统时, 例如A系统(TomcatA)想调用B系统(TomcatB)中的服务, 这时Dubbo就有了用武之地. 首先我们需要B系统在注册中心将自己的Url注册进去, 然后注册中心将Url返还给系统A, 那么系统A就可以调用了. 当然了我这里说的只是Dubbo的一种用法, 在这个项目中使用的也是Dubbo的远程调用功能.

扫描二维码关注公众号,回复: 8670259 查看本文章

4.2、首先我们需要在linux下安装Zookeeper,其次搭建我们的项目,首先是个主项目里面配置了所有子项目可以用到的依赖,其次开始写子项目,子项目要引入父项目的依赖,不要忘记在在配置文件中加入注册中心(zookeeper redis) 其中引入的端口号是你linux中的ip地址,最后启动项目。ps:注意先启动服务提供方, 然后再启动服务消费方.

五、Dubbo优点与缺点

5.1、优点:像调用本地方法一样调用远程方法;只需简单配置,没有任何API侵入。软负载均衡及容错机制。可在内网替代nginx lvs等硬件负载均衡器。服务注册中心自动注册 & 配置管理。不需要写死服务提供者地址,注册中心基于接口名自动查询提供者ip。使用类似zookeeper等分布式协调服务作为服务注册中心,可以将绝大部分项目配置移入zookeeper集群。

5.2、缺点:只支持JAVA语言

发布了3 篇原创文章 · 获赞 1 · 访问量 182

猜你喜欢

转载自blog.csdn.net/hushilin_/article/details/104008377