Dubbo
程序员文章站
2023-04-04 11:50:44
1、概念 Dubbo是一个基于java的RPC(Remote Procedure Call)框架。 1.1、RPC 远程过程调用,即在A系统中,远程调用B系统的某个方法或者函数。 1.1.1、PRC需要解决的问题 (1)、通讯问题 (2)、寻址问题 (3)、序列化与反序列化 调用过程中,数据的传输需 ......
一.Dubbo简介
1.Dubbo是阿里巴巴开源的一款RPC框架, 同时也是一款服务治理框架.
2.在阿里内部, Dubbo是整个体系的一部分, 核心框架.
3.Dubbo的官网:
a)http://dubbo.io
b)http://dubbo.apache.org/zh-cn/
4.背景
随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。
- 单一应用架构
当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键。 - 垂直应用架构
当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。 - 分布式服务架构
当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务复用及整合的分布式服务框架(RPC)是关键。 - 流动计算架构
当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调度和治理中心(SOA)是关键。
5.RPC
Remote Procedure Call, 远程过程调用
6.SOA
Service Oriented Architecture, 面向服务的架构
二.Dubbo的架构简介
所有的实线表示同步操作, 虚线表示异步操作.
- Container, 容器. Dubbo和Spring容器可以进行无缝整合.
- Provider, 服务的生产者.
- Registry, 注册中心, 允许生产者将服务注册到注册中心, 允许消费者从注册中心获取服务.
- Consumer, 服务的消费者.
- Monitor, 监控中心. 对服务的生产者和服务的消费者进行监控, 一般用于管理.
三.注册中心
1.Dubbo支持的注册中心
Dubbo支持多种注册中心, 官方推荐使用Zookeeper作为注册中心. 常见的注册中心:
- Simple注册中心: 测试用注册中心, 生产环境不能使用.
- Multicast注册中心: 通过广播地址的形式实现. 只适合开发阶段(小范围)使用, 生产环境不使用.
- Redis注册中心: 基于Redis实现, 特点是速度快, 效率高, 但是服务器压力较大.
- Zookeeper注册中心: Zookeeper 是 Apacahe Hadoop 的子项目,是一个树型的目录服务,支持变更推送,适合作为 Dubbo 服务的注册中心,工业强度较高,可用于生产环境,并推荐使用.
我们学习使用Zookeeper作为Dubbo的注册中心, 工作示意图:
2.安装Zookeeper
- Zookeeper是java开发的, 需要先安装jdk;
- 安装Zookeeper, 解压缩, 移动目录
- 配置
在安装目录下新建目录data, 用于存放数据
复制并重命名配置文件. Zookeeper使用的配置文件名称应该是zoo.cfg
修改配置, 指定数据存放目录
- 服务管理, 进入安装目录的bin目录下
./zk-server.sh start --> 启动服务
./zk-server.sh stop --> 关闭服务
./zk-server.sh restart --> 重启服务
./zk-server.sh status --> 查看服务状态 - 客户端连接, 执行bin/zk-cli.sh即可默认连接localhost:2181.
四.Dubbo信息传递可选的协议
Dubbo支持多种传输协议, 官方推荐使用dubbo://协议.
1.dubbo协议的特性
缺省协议,使用基于 mina 1.1.7 和 hessian 3.2.1 的 tbremoting 交互。
- 连接个数:单连接
- 连接方式:长连接
- 传输协议:TCP
- 传输方式:NIO 异步传输
- 序列化:Hessian 二进制序列化
- 适用范围:传入传出参数数据包较小(建议小于100K),消费者比提供者个数多,单一消费者无法压满提供者,尽量不要用 dubbo 协议传输大文件或超大字符串。
- 适用场景:常规远程服务方法调用
2.dubbo协议的约束
- 参数及返回值需实现 Serializable 接口
- 参数及返回值不能自定义实现 List, Map, Number, Date, Calendar 等接口,只能用 JDK 自带的实现,因为 hessian 会做特殊处理,自定义实现类中的属性值都会丢失。
- Hessian 序列化,只传成员属性值和值的类型,不传方法或静态变量.
本文地址:https://blog.csdn.net/qq_37206355/article/details/107492865
推荐阅读
-
zheng安装 dubbo安装
-
各大主流微服务技术SpringCloud、SpringCloudAlibaba、Dubbo、Motan、MSEC架构选型对比
-
Dubbo超时
-
【转】Alibaba Dubbo框架同步调用原理分析
-
dubbo admin的使用
-
Java开发中什么是Dubbo SPI(详细讲解使用)
-
dubbo源码阅读之SPI
-
dubbo总结(2)——dubbo的使用场景 springmvc+mybatisdubbo+zookeeperrestful redis分布式缓存spring mvc
-
dubbo与nginx都可以做负载均衡,然而哪个相对来说更优秀?为什么? springmvc+mybatisdubbo+zookeeperrestful redis分布式缓存spring mvc
-
dubbo总结(2)——dubbo的使用场景 springmvc+mybatisdubbo+zookeeperrestful redis分布式缓存spring mvc