热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

dubbo学习一dubbo概述

1,背景1,网站刚开时候的时候可能所有的功能业务都在一个应用里面2,当业务不断复杂,流量不断增多的时候,就需要将原先的一个应用划分成多个独立的应用。3,当分出来的业务越来越多的时候

1,背景

 
技术分享 
技术分享
1,网站刚开时候的时候可能所有的功能业务都在一个应用里面
2,当业务不断复杂,流量不断增多的时候,就需要将原先的一个应用划分成多个独立的应用。
3,当分出来的业务越来越多的时候,应用也变的多而复杂,各个应用之间的交互也必不可少,就需要进行远程服务调用RPC,使用哪个找哪个,调用哪个。
4,当服务越来越多的时候,上面那种用一个找一个的方法,不仅管理混乱而且资源浪费,这时就需要一个服务调度中心来管理所有的服务信息,做为一个服务中心,所有使用者都只要关注服务中心即可。并且还需要不同服务 不同集群不同路由不同容错等等资源合理 运用起来才行。
而dubbo正好解决这样的一系列问题。
 

2,dubbo大体的架构

我的理解

dubbo大体上就是有三个部分,服务提供者,服务消费者,监控中心。服务提供者开发好服务之后,将调用这个服务的地址等信息都注册到一个服务注册中心去(常用zookeeper),通一个服务可以有多个提供者,服务消费者要消费的时候,就从注册中心拿过来自己要消费的服务的多个地址列表(有多个提供者的话),然后按照dobbo自己的软负载均衡算法,来选出一个提供者,去调用。这样,消费者不用去关心谁提供的服务,只需要找服务注册中心即可,而提供者也不需要将配置文件告诉所有消费者,只需要注册到注册中心即可。并且服务的集群负载均衡都是在消费端的,也保证了服务的干净,随时都可以增加减少服务提供者。

官方文字

 
技术分享
技术分享
节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。

调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册自己提供的服务。
2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
 

dubbo的多样化方式

1,支持协议多样化

不同的服务,不同的场景,不同的消费者,可能适合的服务协议不一样,这里,dubbo已经实现了多种协议的提供和调用
     dubbo协议:使用mina,netty,grizzy三种之一来实现。
        rmi协议:使用jdk标准的java.rmi.*来实现
        hessian协议:采用Servlet暴露服务,Dubbo缺省内嵌Jetty作为服务器实现。
        http协议:采用Spring的HttpInvoker实现
        webservice协议:基于apache的cxf来实现
        thrift协议,memcached协议,redis协议     
并且dubbo也支持协议的扩展。
 

2,注册中心多样化

注册中心也实现了多种方式
Multicast注册中心:不需要启动任何中心节点,只要广播地址一样,就可以互相发现,但是组播受网络结构限制,只适合小规模应用或开发阶段使用。
Zookeeper注册中心:Zookeeper是Apacahe Hadoop的子项目,是一个树型的目录服务,支持变更推送,适合作为Dubbo服务的注册中心,工业强度较高,可用于生产环境,并推荐使用
Redis注册中心
Simple注册中心
 

3,dubbo也支持各种扩展

1,协议的扩展,可以根据自己的业务需求来扩展对应的协议,不过一般上也够用, 
2,负载均衡的扩展,如果觉得dubbo的集中负载均衡不够的话,可以自己扩展。
3,注册中心扩展,一般上用zookeeper也行了。
4,序列化的扩展,dubbo默认使用的是 hessian2(阿里修改了下)序列化方法,可扩展成kryo等更高效的。
等等
 
由此来说,dubbo的实现已经可以满足服务集中化管理的多种场景了。可以学学。
 
dubbo的具体使用方法细节参考:http://dubbo.io/Home-zh.htm  写的非常详细。

dubbo学习 一 dubbo概述


推荐阅读
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • andr ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何通过SQL查询从JDE(JD Edwards)系统中提取所有字典数据,涵盖关键表的关联和字段选择。具体包括F0004和F0005系列表的数据提取方法。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • MATLAB实现n条线段交点计算
    本文介绍了一种通过逐对比较线段来求解交点的简单算法。此外,还提到了一种基于排序的方法,但该方法较为复杂,尚未完全理解。文中详细描述了如何根据线段端点求交点,并判断交点是否在线段上。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
author-avatar
克乄浪木守
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有