互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,Dubbo是一个分布式服务框架,在这种情况下诞生的。现在核心业务抽取出来,作为独立的服务,使前端应用能更快速和稳定的响应。
第一:介绍Dubbo背景
大规模服务化之前,应用可能只是通过RMI或Hessian等工具,简单的暴露和引用远程服务,通过配置服务的URL地址进行调用,通过F5等硬件进行负载均衡。
(1) 当服务越来越多时,服务URL配置管理变得非常困难,F5硬件负载均衡器的单点压力也越来越大。
此时需要一个服务注册中心,动态的注册和发现服务,使服务的位置透明。
并通过在消费方获取服务提供方地址列表,实现软负载均衡和Failover,降低对F5硬件负载均衡器的依赖,也能减少部分成本。
(2) 当进一步发展,服务间依赖关系变得错踪复杂,甚至分不清哪个应用要在哪个应用之前启动,架构师都不能完整的描述应用的架构关系。
这时,需要自动画出应用间的依赖关系图,以帮助架构师理清理关系。
(3) 接着,服务的调用量越来越大,服务的容量问题就暴露出来,这个服务需要多少机器支撑?什么时候该加机器?
为了解决这些问题,第一步,要将服务现在每天的调用量,响应时间,都统计出来,作为容量规划的参考指标。
其次,要可以动态调整权重,在线上,将某台机器的权重一直加大,并在加大的过程中记录响应时间的变化,直到响应时间到达阀值,记录此时的访问量,再以此访问量乘以机器数反推总容量。
第二:Dubbo的简介
Dubbo是一个分布式服务框架,解决了上面的所面对的问题,Dubbo的架构如图所示:
节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。
调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册自己提供的服务。
2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
Dubbo提供了很多协议,Dubbo协议、RMI协议、Hessian协议,我们查看Dubbo源代码,有各种协议的实现,如图所示:
我们之前没用Dubbo之前时,大部分都使用Hessian来使用我们服务的暴露和调用,利用HessianProxyFactory调用远程接口。
上面是参考了Dubbo官方网介绍,接下来我们来介绍SpringMVC、Dubbo、Zookeeper整合使用。
第三:Dubbo与Zookeeper、SpringMVC整合使用
第一步:在Linux上安装Zookeeper
Zookeeper作为Dubbo服务的注册中心,Dubbo原先基于数据库的注册中心,没采用Zookeeper,Zookeeper一个分布式的服务框架,是树型的目录服务的数据存储,能做到集群管理数据 ,这里能很好的作为Dubbo服务的注册中心,Dubbo能与Zookeeper做到集群部署,当提供者出现断电等异常停机时,Zookeeper注册中心能自动删除提供者信息,当提供者重启时,能自动恢复注册数据,以及订阅请求。我们先在linux上安装Zookeeper,我们安装最简单的单点,集群比较麻烦。
http://doc.okbase.net/congcong68/archive/112508.html
相关推荐
在IT行业中,集成Dubbo、Zookeeper和SpringMVC是一项常见的任务,这三者都是Java生态中的重要组件。本文将详细讲解如何将这三个组件整合在一起,构建一个高效、可扩展的微服务架构。 首先,Dubbo是阿里巴巴开源的一...
### Dubbo与Zookeeper、SpringMVC的整合与使用详解 #### 一、Dubbo背景与概述 随着互联网技术的快速发展,网站应用的规模日益扩大,传统的垂直应用架构已难以满足日益增长的需求。为了提高系统的扩展性和灵活性,...
本教程将主要介绍 Dubbo 的基本概念、Dubbo 的架构、Dubbo 与 Zookeeper 的整合、Dubbo 与 SpringMVC 的整合等方面的知识点。 一、Dubbo 基本概念 Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC ...
**SpringMVC与Dubbo整合步骤**: 1. 在SpringMVC项目中添加Dubbo相关依赖。 2. 配置Dubbo服务提供者和消费者。 3. 使用SpringMVC注解定义RESTful API。 4. 通过Dubbo的API调用远程服务。 通过这种方式,可以实现...
整合Dubbo、Zookeeper和SpringMVC的步骤如下: 1. **设置环境**:确保所有必要的依赖库(如dubbo、zookeeper、spring-mvc等)已添加到项目中,可以通过Maven或Gradle进行管理。 2. **创建服务提供者**:在服务提供...
springMVC+dubbo+zookeeper框架整合基本Jar包所需。 spring、springMVC、duboo、zkcliend、zookeeper、netty...............
【标题】"dubbo+zookeeper+spring+springMVC+mybatis" 描述了一个基于这些技术构建的服务消费方与服务提供方的项目架构。在这个架构中,`Dubbo`是核心的服务框架,它负责服务的注册与发现;`Zookeeper`作为注册中心...
综上所述,"zookeeper+dubbo+springmvc项目整合"是一个完整的微服务解决方案,利用Zookeeper实现服务的注册与发现,Dubbo进行服务间通信,SpringMVC处理HTTP请求,MongoDB存储非结构化数据,而Maven则确保项目构建与...
《Dubbo、Zookeeper与SpringMVC整合深度解析》 在现代互联网开发中,服务化是不可或缺的一部分,而Dubbo作为阿里巴巴开源的一款高性能、轻量级的服务治理框架,深受广大开发者喜爱。它提供了服务注册、服务发现、...
综上所述,Dubbo、Zookeeper和SpringMVC的整合,能够构建一个高效、稳定且易于管理的分布式服务系统。服务提供者通过Zookeeper注册服务,服务消费者从Zookeeper获取服务信息,SpringMVC作为前端控制器,协调HTTP请求...
本文档主要介绍了如何利用Dubbo、Zookeeper以及SpringMVC来构建一个分布式的微服务架构。这种架构能够有效地解决服务发现、负载均衡、故障恢复等问题。 ##### 1.2 节点角色说明 - **Provider**: 提供服务的服务器,...
本项目通过整合Dubbo、Zookeeper和SpringMVC,构建了一个完整的分布式服务治理框架,以实现高效的服务注册、发现、管理和监控。 首先,我们要理解Dubbo的核心功能。Dubbo提供了服务提供者(Provider)和服务消费者...
【标题】"dubbo+zookeeper+SpringMVC Demo"是一个示例项目,它演示了如何在实际应用中整合这三个关键组件:Dubbo、Zookeeper和SpringMVC。Dubbo是阿里巴巴开源的一个高性能、轻量级的服务框架,用于构建微服务架构;...
接下来,我们需要将Dubbo与Zookeeper整合。Dubbo利用Zookeeper作为注册中心,服务提供者会向Zookeeper注册自己的服务,而服务消费者则通过查询Zookeeper获取服务提供者的地址。配置步骤如下: 1. 在服务提供者的配置...
"dubbo/zookeeper/springMVC demo"就是一个这样的示例,它演示了如何将阿里巴巴的Dubbo服务框架、Apache ZooKeeper注册中心以及Spring MVC web框架整合在一起,以实现微服务架构中的服务发现和服务调用。 首先,...
整合Dubbo、Zookeeper和SpringMVC可以让开发者更加便捷地构建分布式系统,通过Zookeeper实现服务的自动注册与发现,SpringMVC提供友好的Web接口,而Dubbo则作为服务间通信的桥梁,确保服务的高可用性和性能。...
在IT行业中,分布式服务框架是构建大型互联网应用的关键技术之一,Dubbo、Zookeeper和SpringMVC这三者就是这样的核心组件。这篇介绍将详细解析它们的用途、工作原理以及如何将它们集成到一个入门级项目中。 Dubbo是...
本示例"**DUBBO+Zookeeper小例子**"旨在演示如何利用SpringMVC、Dubbo和Zookeeper来实现一个微服务架构。这是一次将这些组件集成到一起的实际操作,通过IDEA(IntelliJ IDEA)开发环境进行。在开始之前,确保你已...