六:Dubbo与Zookeeper、SpringMvc整合和动用

DUBBO同ZOOKEEPER、SPRINGMVC整合与运

互联网的前行,网站采取的局面不断扩大,常规的直下架构已束手无策回答,分布式服务架构和流动计算架构势在必行,Dubbo是一个分布式服务框架,在这种景象下诞生的。现在中心工作抽取出来,作为单身的服务,使前端采用能够再快捷和稳定性的应。

第一:介绍Dubbo背景

Dubbo是一个分布式服务框架,解决了端的所当的问题,Dubbo的架如图所示:

最主要核心部件:

Remoting: 网络通信框架,实现了 sync-over-async 和 request-response
消息机制.

RPC: 一个远程过程调用的架空,支持负载均衡、容灾和集群效益

Registry: 服务目录框架用于服务之注册与服务事件发表暨订阅

Dubbo工作原理

图片 1

Provider

爆出服务方称之为“服务提供者”。

Consumer

调用远程服务方称之为“服务消费者”。

Registry

服务登记和发现的着力目录服务称之为“服务登记中心”。

Monitor

统计服务之调用次调和调用时间的日志服务称之为“服务监控中心”。

(1) 连通性:

注册中心负责服务地方的报及寻找,相当给目录服务,服务提供者和顾客只有以起步时跟登记中心交互,注册中心未转发呼吁,压力比较小

督察中心负责统计各服务调用次数,调用时间相当,统计先以外存汇总后各级分钟一不善发送到监督中心服务器,并盖表显示

劳提供者向注册中心注册其提供的劳务,并汇报调用时间及监控中心,此时间不分包网络支付

劳消费者于注册中心获得服务提供者地址列表,并基于负荷算法直白调用提供者,同时反映调用时间及监控中心,此时间包含网络支付

报中心,服务提供者,服务消费者三者之间都为抬高连,监控中心除了

报中心通过抬高连感知服务提供者的是,服务提供者宕机,注册中心以立即推送事件通报消费者

报中心以及督查中心总体宕机,不影响都运行的提供者和消费者,消费者以地面缓存了提供者列表

报中心及监督中心还是可选的,服务消费者可直连服务提供者

(2) 健状性:

监察中心宕掉不影响使,只是丢失部分采样数据

数据库宕掉后,注册中心按照能通过缓存提供服务列表查询,但不可知注册新劳动

报中心对顶集群,任意一华宕掉后,将活动切换到外一样大

报中心总体宕掉后,服务提供者和劳务消费者以会由此地面缓存通讯

劳动提供者无状态,任意一贵宕掉后,不影响下

劳务提供者全部宕掉后,服务消费者以将无法以,并尽次重连等待服务提供者恢复

(3) 伸缩性:

挂号中心也对顶集群,可动态增加机械配置实例,所有客户端将电动发现新的报中心

劳务提供者无状态,可动态增加机械配置实例,注册中心将推送新的服务提供者信息被消费者

节点角色说明:

Provider: 暴露服务之服务提供方。

Consumer: 调用长途服务之劳务消费方。

Registry: 服务登记和发现的挂号中心。

Monitor: 统计服务的调用次调和调用时间之监察中心。

Container: 服务运作容器。

调用关系说明:

  1. 劳容器负责启动,加载,运行服务提供者。

  2. 劳务提供者在开行时,向登记中心登记自己提供的劳务。

  3. 服务消费者在开行时,向注册中心订阅自己所欲的劳务。

3.
注册中心返回服务提供者地址列表给消费者,如果起变动,注册中心以根据长连推送变更数据让买主。

4.
劳动消费者,从提供者地址列表中,基于软负载均衡算法,选同大提供者进行调用,如果调用失败,再摘另一样宝调用。

5.
劳动消费者与供者,在内存中凡调用次数及调用时间,定时每分钟发送一软统计数据到监督中心。

放置功能(只排了同样有的功能)

1.用户管理:用户是系操作者,该意义主要完成系统用户配置。

2.部门管理:配置体系组织机关(公司、部门、小组),树结构表现,可随意调整上下级。

3.区域管理:系统都会区域型,如:国家、省市、地购买、区县城之保障。

4.菜单管理:配置体系菜单,操作权限,按钮权限标识等。

5.角色管理:角色菜单权限分配、设置角色以机关进行数量范围权限划分。

6.字典管制:对系统中常使用的有较为恒定的数据开展维护,如:是否、男女、类别、级别等。

7.操作日志:系统常规操作日志记录以及询问;系统充分信息日志记录和查询。

8.连接池监视:监视当期系统数据库连接池状态,可进展解析SQL找来系统特性瓶颈。

9.办事流引擎:实现业务工单流转、在线流程设计器。

开发工具

1.Eclipse IDE:采用Maven项目管理,模块化。

2.代码生成:通过界面方式大概布置,自动生成相应代码,目前包括三栽颇成道(增删改查):单表、一对大多、树结构。生成后底代码如果不需要注意美观程度,生成后就可用。

技能选型(只排了扳平组成部分技术)

1、后端

劳动框架:Dubbo、zookeeper、Rest服务

缓存:Redis、ehcache

消息中间件:ActiveMQ

负载均衡:Nginx

分布式文件:FastDFS

数据库连接池:Alibaba Druid 1.0

主导框架:Spring framework

平安框架:Apache Shiro 1.2

视图框架:Spring MVC 4.0

服务端验证:Hibernate Validator 5.1

布局框架:SiteMesh 2.4

工作流引擎:Activiti 5.15

任务调度:quartz 1.8.5

持久层框架:MyBatis 3.2

日志管理:SLF4J 1.7、Log4j

工具类:Apache Commons、Jackson 2.2、Xstream 1.4、Dozer 5.3、POI

2、前端

JS框架:JQuery 1.9。

CSS框架: Bootstrap 4 metronic

客户端验证:JQuery Validation Plugin。

富文本:CKEcitor

文本管理:CKFinder

动态页签:Jerichotab

多少表格:jqGrid

对话框:jQuery jBox

陶铸结构控件:jQuery zTree

其余零件:Bootstrap 4 metronic

3、支持

服务器中件:Tomcat 6、7、Jboss 7、WebLogic 10、WebSphere 8

数据库支持:目前就提供mysql数据库的支撑,但不制止数据库,下只版升级多数据源切换和数据库读写分离:
如:Oracle、SqlServer、H2等

支撑开发环境:Eclipse、MyEclipse、Ras、Idea等

藏介绍:

源码结构

图片 2

 

相关文章