欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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.背景
随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。
Dubbo

  • 单一应用架构
      当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键。
  • 垂直应用架构
      当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。
  • 分布式服务架构
      当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务复用及整合的分布式服务框架(RPC)是关键。
  • 流动计算架构
      当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调度和治理中心(SOA)是关键。

5.RPC
Remote Procedure Call, 远程过程调用
6.SOA
Service Oriented Architecture, 面向服务的架构

二.Dubbo的架构简介
Dubbo
所有的实线表示同步操作, 虚线表示异步操作.

  • Container, 容器. Dubbo和Spring容器可以进行无缝整合.
  • Provider, 服务的生产者.
  • Registry, 注册中心, 允许生产者将服务注册到注册中心, 允许消费者从注册中心获取服务.
  • Consumer, 服务的消费者.
  • Monitor, 监控中心. 对服务的生产者和服务的消费者进行监控, 一般用于管理.

三.注册中心

1.Dubbo支持的注册中心
 Dubbo支持多种注册中心, 官方推荐使用Zookeeper作为注册中心. 常见的注册中心:

  • Simple注册中心: 测试用注册中心, 生产环境不能使用.
  • Multicast注册中心: 通过广播地址的形式实现. 只适合开发阶段(小范围)使用, 生产环境不使用.
  • Redis注册中心: 基于Redis实现, 特点是速度快, 效率高, 但是服务器压力较大.
  • Zookeeper注册中心: Zookeeper 是 Apacahe Hadoop 的子项目,是一个树型的目录服务,支持变更推送,适合作为 Dubbo 服务的注册中心,工业强度较高,可用于生产环境,并推荐使用.

我们学习使用Zookeeper作为Dubbo的注册中心, 工作示意图:
Dubbo
2.安装Zookeeper

  • Zookeeper是java开发的, 需要先安装jdk;
  • 安装Zookeeper, 解压缩, 移动目录
  • 配置
     在安装目录下新建目录data, 用于存放数据
     复制并重命名配置文件. Zookeeper使用的配置文件名称应该是zoo.cfg
     修改配置, 指定数据存放目录
    Dubbo
  • 服务管理, 进入安装目录的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

相关标签: dubbo