dubbo项目结构

1.概述

首先dubbo项目是一个基于maven 的项目 , 我们会发现模块非常多


dubbo模块.png

2.模块分包

dubbo模块分包.png

2.dubbo-common模块

dubbo-common 公共逻辑模块:包括 Util 类和通用模型。

dubbo-common.png

dubbo-remoting 远程通信模块:提供客户端和服务端的通信功能

dubbo-remoting模块.png
  • dubbo-remoting-zookeeper: 是zookeeper 的客服端通信,负责服务端和消费方与zookeeper进行通信 。
  • dubbo-remoting-api: 定义服务方和消费方之间的通信接口
  • dubbo-remoting-grizzly ,基于 Grizzly 实现。
  • dubbo-remoting-http ,基于 Jetty 或 Tomcat 实现。
  • dubbo-remoting-mina ,基于 Mina实现。
  • dubbo-remoting-netty ,基于 Netty 3 实现。
  • dubbo-remoting-netty4 ,基于 Netty 4实现。
  • dubbo-remoting-p2p ,P2P 服务器。注册中心 dubbo-registry-multicast 项目 的使用该项目
    dubbo默认使用的也是生产中使用的最多的通信方式是netty , 所以我们只需看dubbo-remoting-api + dubbo-remoting-netty4 以及和zk 的通信模块 dubbo-remoting-zookeeper

dubbo-rpc

远程调用模块:抽象各种协议,以及动态代理,只包含一对一的调用,不关心集群的管理,dubbo-rpc 是整个dubbo的一个核心模块。

dubbo-rpc模块.png
  • dubbo-rpc-api :抽象各种协议以及动态代理,实现了一对一的调用。
    其他模块则提供对应的协议实现 。在 《用户指南 —— 协议参考手册》 中,可以看到每种协议的介绍。

dubbo-cluster

集群模块:将多个服务提供方伪装为一个提供方,包括:负载均衡, 集群容错,路由,分组聚合等。集群的地址列表可以是静态配置的,也可以是由注册中心下发。

dubbo-clsuter.png

dubbo-registry

注册中心模块:基于注册中心下发地址的集群方式,以及对各种注册中心的抽象。

注册中心.png

dubbo-registry-api : 注册中心的接口定义 , 其他模块则是各种对注册中心的实现《用户指南 —— 注册中心参考手册》 有详细介绍各种注册中心

dubbo-monitor

监控模块: 统计调用次数,时间,拓展参见 《Dubbo 开发指南 —— 监控中心扩展》

dubbo-config

配置模块 : 是dubbo对外API , 用户通过config使用dubbo

dubbo-config.png

dubbo-config-api : 实现了 API 配置属性配置 功能。
dubbo-config-spring :实现了 XML 配置注解配置 功能。

dubbo-container

dubbo容器模块 : 以简单的main 方法启动容器


dubbo容器.png

dubbo-filter

过滤器模块 :提供了内置过滤器

dubbo-filter.png

dubbo-filter-cache : 缓存过滤器 , 拓展参考 《Dubbo 用户指南 —— 结果缓存》《Dubbo 开发指南 —— 缓存拓展》 文档。
dubbo-filter-validation :参数校验过滤器 , 拓展参考 《Dubbo 用户指南 —— 参数验证》《Dubbo 开发指南 —— 验证扩展》 文档。

dubbo-plugin

插件模块 : 提供了内置插件
dubbo-qos : 提供在线运维命令 ,拓展参考 《Dubbo 用户指南 —— 新版本 telnet 命令使用说明》《Dubbo 开发指南 —— Telnet 命令扩展》 文档。

hessian-lite

dubbo对hessian2序列化的部分精简, 改进。

dubbo-demo

dubbbo 一个快速启动的demo

dubbo-test

dubbo 测试模块

maven-bom

dubbo-dependencies-bom :定义dubbo 依赖第三方库的版本号 , 在parent 中有引入
dubbo-bom :定义dubbo各模块的版本号

bom依赖.png

dubbo-all

dubbo/all/pom : 定义了 Dubbo 的打包脚本。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355

推荐阅读更多精彩内容

  • 1:RPC协议扩展,封装远程调用细节 扩展接口: com.alibaba.dubbo.rpc.Protocol c...
    漫步_2310阅读 2,208评论 0 11
  • 本文转自:Dubbo架构设计详解,原作者是:时延军 Dubbo是Alibaba开源的分布式服务框架,它最大的特点是...
    程序熊大阅读 3,458评论 3 45
  • 文/树鲸 15年的阅读状态: 传记2,随笔4,短篇集5,科幻11,推理11,长篇16,总计49本。 和14年的阅读...
    树鲸阅读 3,061评论 18 82
  • 清明思 文 /若伊 梦里哭了一夜 醒来 眼见一双颤动的睫毛下 满是 挂满忧伤的 心碎 清明 文 / 二月鸟 ——回...
    默墨舞文阅读 563评论 0 4
  • 女孩说我叫诗莹。 我叫李昂。 你带我走好不好? 可以。 接着来了一个拿刀的待卫,把李昂砍成半条命了。 接着诗莹着急...
    青柠味阅读 66评论 0 0