Dubbo阿里巴巴内部SOA治理方案和服务的核心框架。每天2000+ 个服务提供3,000,000,000+ 次訪问量支持,并被广泛应用于阿里巴巴集团的各成员网站。Dubbo自2011年开源后,已被很多非阿里系公司使用。

Dubbo[]是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。

其核心部分包括:

  • 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包含多种线程模型。序列化。以及“请求-响应”模式的信息交换方式。
  • 集群容错: 提供基于接口方法的透明远程过程调用,包含多协议支持。以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
  • 自己主动发现: 基于注冊中心文件夹服务,使服务消费方能动态的查找服务提供方,使地址透明。使服务提供方能够平滑添加或降低机器。

Dubbo能做什么?

  • 透明化的远程方法调用。就像调用本地方法一样调用远程方法,仅仅需简单配置。没有不论什么API侵入。

  • 软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,降低单点。
  • 服务自己主动注冊与发现,不再须要写死服务提供方地址,注冊中心基于接口名查询服务提供者的IP地址,而且可以平滑加入或删除服务提供者。

高速启动

Dubbo採用全Spring配置方式。透明化接入应用,相应用没有不论什么API侵入,仅仅需用Spring载入Dubbo的配置就可以,Dubbo基于Spring的Schema扩展进行载入。
假设不想使用Spring配置。而希望通过API的方式进行调用(不推荐),请參见:API配置 (+)

服务提供者

完整安装步骤,请參见:演示样例提供者安装 (+)

定义服务接口: (该接口需单独打包,在服务提供方和消费方共享)

DemoService.java
package
com.alibaba.dubbo.demo;
 
public
interface
DemoService {
 
    String sayHello(String name);
 
}

在服务提供方实现接口:(对服务消费方隐藏实现)

DemoServiceImpl.java
package
com.alibaba.dubbo.demo.provider;
 
import
com.alibaba.dubbo.demo.DemoService;
 
public
class
DemoServiceImpl implementsDemoService {
 
    publicString sayHello(String name) {
        return"Hello "
+ name;
    }
 
}

用Spring配置声明暴露服务:

provider.xml
<?xmlversion="1.0"encoding="UTF-8"?

>

    xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans.xsd       
http://code.alibabatech.com/schema/dubbo        http://code.alibabatech.com/schema/dubbo/dubbo.xsd"
>
 
    <!-- 提供方应用信息。用于计算依赖关系 -->
    <dubbo:applicationname="hello-world-app" />
 
    <!-- 使用multicast广播注冊中心暴露服务地址 -->
    <dubbo:registryaddress="multicast://224.5.6.7:1234"/>
 
    <!-- 用dubbo协议在20880port暴露服务 -->
    <dubbo:protocolname="dubbo"port="20880"/>
 
    <!-- 声明须要暴露的服务接口 -->
    <dubbo:serviceinterface="com.alibaba.dubbo.demo.DemoService"ref="demoService"/>
 
    <!-- 和本地bean一样实现服务 -->
    <beanid="demoService"class="com.alibaba.dubbo.demo.provider.DemoServiceImpl"/>
 
</beans>

载入Spring配置:

Provider.java
import
org.springframework.context.support.ClassPathXmlApplicationContext;
 
public
class
Provider {
 
    publicstatic
void main(String[] args)
throws Exception {
        ClassPathXmlApplicationContext context =new
ClassPathXmlApplicationContext(newString[] {"http://10.20.160.198/wiki/display/dubbo/provider.xml"});
        context.start();
 
        System.in.read();// 按随意键退出
    }
 
}

服务消费者

完整安装步骤。请參见:演示样例消费者安装 (+)

通过Spring配置引用远程服务:

consumer.xml
<?xmlversion="1.0"encoding="UTF-8"?>
    xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans.xsd       
http://code.alibabatech.com/schema/dubbo        http://code.alibabatech.com/schema/dubbo/dubbo.xsd"
>
 
    <!-- 消费方应用名。用于计算依赖关系,不是匹配条件。不要与提供方一样 -->
    <dubbo:applicationname="consumer-of-helloworld-app" />
 
    <!-- 使用multicast广播注冊中心暴露发现服务地址 -->
    <dubbo:registryaddress="multicast://224.5.6.7:1234"/>
 
    <!-- 生成远程服务代理。能够和本地bean一样使用demoService -->
    <dubbo:referenceid="demoService"interface="com.alibaba.dubbo.demo.DemoService"/>
 
</beans>

载入Spring配置,并调用远程服务:(也能够使用IoC注入)

Consumer.java
import
org.springframework.context.support.ClassPathXmlApplicationContext;
import
com.alibaba.dubbo.demo.DemoService;
 
public
class
Consumer {
 
    publicstatic
void main(String[] args)
throws Exception {
        ClassPathXmlApplicationContext context =new
ClassPathXmlApplicationContext(newString[] {"http://10.20.160.198/wiki/display/dubbo/consumer.xml"});
        context.start();
 
        DemoService demoService = (DemoService)context.getBean("demoService");//
获取远程服务代理
        String hello = demoService.sayHello("world");// 运行远程方法
 
        System.out.println( hello );// 显示调用结果
    }
 
}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

熟人Dubbo 系列1-Dubbo什么的更多相关文章

  1. 分布式学习系列【dubbo入门实践】

    分布式学习系列[dubbo入门实践] dubbo架构 组成部分:provider,consumer,registry,monitor: provider,consumer注册,订阅类似于消息队列的注册 ...

  2. Dubbo系列_概述

    一.本文目的         学习使用Dubbo也有一段时间了,准备写一个系列文章介绍Dubbo的相关知识和使用,供自己以后回顾和他人学习.有兴趣的同学可以加入群:74085440一起探讨 二.书写计 ...

  3. 深度学习Dubbo系列(入门开篇)

    此文档为系列学习文档 这系列文档详细讲解了dubbo的使用,基本涵盖dubbo的所有功能特性.在接下来的文章里会详细介绍. 如果你正依赖dubbo作为你业务工程的RPC通信框架,这里可以作为你的参考手 ...

  4. dubbo系列四、dubbo服务暴露过程源码解析

    一.代码准备 1.示例代码 参考dubbo系列二.dubbo+zookeeper+dubboadmin分布式服务框架搭建(windows平台) 2.简单了解下spring自定义标签 https://w ...

  5. Dubbo 系列(05-1)服务发布

    目录 Dubbo 系列(05-1)服务发布 Spring Cloud Alibaba 系列目录 - Dubbo 篇 1. 背景介绍 1.1 服务暴露整体机制 2. 源码分析 2.1 前置工作 2.2 ...

  6. Dubbo 系列(07-5)集群容错 - Mock

    Dubbo 系列(07-5)集群容错 - Mock [toc] Spring Cloud Alibaba 系列目录 - Dubbo 篇 1. 背景介绍 相关文档推荐: Dubbo 实战 - 服务降级 ...

  7. Dubbo 系列(07-4)集群容错 - 集群

    BDubbo 系列(07-4)集群容错 - 集群 [toc] Spring Cloud Alibaba 系列目录 - Dubbo 篇 1. 背景介绍 相关文档推荐: Dubbo 集群容错 - 实战 D ...

  8. Dubbo 系列(07-3)集群容错 - 负载均衡

    目录 Dubbo 系列(07-3)集群容错 - 负载均衡 Spring Cloud Alibaba 系列目录 - Dubbo 篇 1. 背景介绍 1.1 负载均衡算法 1.2 继承体系 2. 源码分析 ...

  9. Dubbo 系列(07-2)集群容错 - 服务路由

    目录 Dubbo 系列(07-2)集群容错 - 服务路由 1. 背景介绍 1.1 继承体系 1.2 SPI 2. 源码分析 2.1 创建路由规则 2.2 RouteChain 2.3 条件路由 Dub ...

随机推荐

  1. Android App 内存泄漏Handler

    Android App 内存泄露之Handler Handler也是造成内存泄露的一个重要的源头,主要Handler属于TLS(Thread Local Storage)变量,生命周期和Activit ...

  2. 深入了解回调函数Java

    打回来.我第一次看到Java编程思想,后来Observer模式也适用于一个回调函数的想法.但是,一直没有重视,在处于劣势的最终面试,越来越明白为什么那么多人说Java编程思想,这本书应该是一遍又一遍, ...

  3. SVA(system verilog assertions)基础

    1什么是断言: 断言就是在模拟过程中依据我们事先安排好的逻辑是不是发生了,假设发生断言成功.否则断言失败. 2断言的运行分为:预备(preponed)观察(observed)响应(reactive). ...

  4. xp硬盘安装Fedora14 过程记录及心得体会(fedora14 live版本680M 和fedora14 DVD版本3.2G的选择)

    这次电脑奔溃了,奇怪的是直接ghost覆盖c盘竟然不中.之前电脑上硬盘安装的fedora14操作系统,也是双系统.不知道是不是这个问题,记得同学说过,在硬盘装fedora之后,要手动修改c盘隐藏的那个 ...

  5. Sliverlight之 画刷

    1,5种画刷 (见Project15) (1)TextBlock控件中的Forground和BackGround属性是一个什么对象?它在前台的完整的写法是什么?(实际是.net做了一个转换,可以直接写 ...

  6. jquery省市区三级联动

    jquery省市区三级联动(数据来源国家统计局官网)内附源码下载 很久很久没有写博了. 今天更新了项目的省市区三级联动数据,更新后最新的海南三沙都有,分享给所有需要的小伙伴们... JQUERY + ...

  7. OOP思想

    OOP思想 读者朋友们大家好,我们今天这一讲就接着前面的封装继续讲解,今天就是在前面内容上面的升级,OOP思想中的继承,我们就先来解释一下继承到底是什么意思,我们在什么地方会用到继续. 继承就是,后代 ...

  8. Windows下效率必备软件

    AutoHotKey: 神器!神器!神器!当然也得看使用者咯(^__^) 嘻嘻…… Listary: 本地搜索神器,当然还有别的作用,More&More. Launchy : 快速启动安装的应 ...

  9. linux进程通信之共享内存

    共享内存同意两个或多个进程共享一给定的存储区,由于数据不须要来回复制,所以是最快的一种进程间通信机制.共享内存能够通过mmap()映射普通文件(特殊情况下还能够採用匿名映射)机制实现,也能够通过系统V ...

  10. Cookie概念

    ASP.NET Cookie概念.CURD操作.原理.实际运用   会话就WEB开发来说,一个会话就是你通过浏览器与服务器之间的一次通话,只不过这种通话是以用浏览器浏览的方式来实现的. 就会话的应用来 ...