Dubbo介绍(一)

最近真的是特别的懒 博客 空了好多天都不愿意写
桌面还有留了快一个月的hadoop的 shuffer图片 一直懒得去写原理
跟最近的懒散分不开 先补上dubbo的基本介绍和开发吧、
半年前就想学dubbo和cloud 现在 到了年头抓紧时间补上吧 ,一直说给SpringBoot开个专题好好写写 也没有写几篇 年前 把这些全都补上。
在整整ELK 就写个年终总结吧。

废话不多说 开扯:

何为dubbo 何为rpc
说道RPC 肯定是分布式的了 分布式调用 举个例子 就是你要调用方法获取数据(返回值 ) ,但是 数据在别人家公司的数据库里 咋办?
这时rpc价值就来了 ,如何像调用本地的方法一样调用远程主机的方法,这就是RPC干的事了。且Dubbo是面向服务的体系 SOA的。面向服务治理。
之前我写的数据接入 都是基于soap的 xml形式的方式获取数据 ,浪费带宽 但是没办法 ,国*公司数据格式都必须是xml 我也么办法 ,用的是axis WebService框架 还没有用spring的cxf 项目都是我一个人开发,所以蛋疼之处很多 。
现在开始 说说 dubbo 是啥 ?道理通俗易懂注意 长篇复制粘贴来了:

Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案
其核心部分包含:
1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。
2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。
Dubbo的优势:
1.透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。
2.软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。
3. 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

讲解:
其中涉及到了NIO 非堵塞IO 数据的交互 要么是基于HTTP要么是TCP 等等 。关于NIO的知识 我之后再补补
负载均衡 :总所周知 硬负载均衡就是F5 软负载均衡是Nginx等等。
我有幸在世界五百强第一(自嘲)的公司 看到了F5。确实很牛逼。
注册中心:Zookeeper 这个我学过大数据所以对于Zookeeper的理解看一看做是一个具有临时和永久存储信息的一个东西。除此之外它具有监测机制 。具体大家可以在学一学。

Dubbo的基本架构图:
这里写图片描述

Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次数和调用时间的监控中心。
Container: 服务运行容器。

步骤说明:
0.provider在容器中 加载 启动
1.provider在启动过程中 向zookeeper(注册中心)注册服务
2.consumer启动 向注册中心 订阅服务
3.注册中心 向consumer提供服务提供者的地址列表
4.服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5.服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值