MyException - 我的异常网
当前位置:我的异常网» 综合 » dubbo 课程

dubbo 课程

www.MyException.Cn  网友分享于:2015-04-13  浏览:0次
dubbo 教程
先给出阿里巴巴dubbo的主页:http://code.alibabatech.com/wiki/display/dubbo/Home-zh

自己的demo下载地址:http://download.csdn.net/detail/u012049463/6763315



1. Dubbo是什么?

Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有dubbo这样的分布式服务框架的需求,并且本质上是个服务调用的东东,说白了就是个远程服务调用的分布式框架
其核心部分包含:
1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。
2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。
2. Dubbo能做什么?
1.透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。     
2.软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。
3. 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

Dubbo采用全Spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spring的Schema扩展进行加载。


3. dubbo的架构
dubbo架构图如下所示:

节点角色说明:

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

       Consumer: 调用远程服务的服务消费方。

       Registry: 服务注册与发现的注册中心。

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

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

Dubbo采用全Spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spring的Schema扩展进行加载。如果不想使用Spring配置,而希望通过API的方式进行调用(不推荐),可以参见:

http://code.alibabatech.com/wiki/display/dubbo/User+Guide-zh#UserGuide-zh-API%E9%85%8D%E7%BD%AE

下面我们就来看看spring配置方式的写法。
服务提供者:

1. 下载zookeeper注册中心,下载地址:http://www.apache.org/dyn/closer.cgi/zookeeper/  下载后解压即可,进入D:\apach-zookeeper-3.4.5\bin,

双击zkServer.cmd启动注册中心服务。
2. 定义服务接口: (该接口需单独打包,在服务提供方和消费方共享)

    [java] view plaincopy
        package com.unj.dubbotest.provider; 
         
        import java.util.ArrayList; 
        import java.util.LinkedList; 
        import java.util.List; 
         
         
        public class DemoService{ 
             
             public String sayHello(String name); 
             public List getUsers() ; 
        } 


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



[html] view plaincopy在CODE上查看代码片派生到我的代码片

    package com.unj.dubbotest.provider; 
     
    import java.util.ArrayList; 
    import java.util.LinkedList; 
    import java.util.List; 
     
     
    public class DemoServiceImpl implements DemoService{ 
         
         public String sayHello(String name) { 
                return "Hello " + name; 
         } 
         public List getUsers() { 
             List list = new ArrayList(); 
             User u1 = new User(); 
             u1.setName("jack"); 
             u1.setAge(20); 
             u1.setSex("男"); 
              
             User u2 = new User(); 
             u2.setName("tom"); 
             u2.setAge(21); 
             u2.setSex("女"); 
              
             User u3 = new User(); 
             u3.setName("rose"); 
             u3.setAge(19); 
             u3.setSex("女"); 
              
             list.add(u1); 
             list.add(u2); 
             list.add(u3); 
             return list; 
         } 
    } 

用Spring配置声明暴露服务:

[html] view plaincopy在CODE上查看代码片派生到我的代码片

    <?xml version="1.0" encoding="UTF-8"?> 
    <beans xmlns="http://www.springframework.org/schema/beans" 
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" 
        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 
            "> 
      
        <!-- 具体的实现bean --> 
        <bean id="demoService" class="com.unj.dubbotest.provider.DemoServiceImpl" /> 
         
        <!-- 提供方应用信息,用于计算依赖关系 --> 
        <dubbo:application name="xixi_provider"  /> 
      
        <!-- 使用multicast广播注册中心暴露服务地址  
        <dubbo:registry address="multicast://224.5.6.7:1234" />--> 
       
        <!-- 使用zookeeper注册中心暴露服务地址 --> 
        <dubbo:registry address="zookeeper://127.0.0.1:2181" />  
       
        <!-- 用dubbo协议在20880端口暴露服务 --> 
        <dubbo:protocol name="dubbo" port="20880" /> 
      
        <!-- 声明需要暴露的服务接口 --> 
        <dubbo:service interface="com.unj.dubbotest.provider.DemoService" ref="demoService" /> 
         
    </beans> 

加载Spring配置,启动服务:


[html] view plaincopy在CODE上查看代码片派生到我的代码片

    package com.unj.dubbotest.provider; 
     
    import org.springframework.context.support.ClassPathXmlApplicationContext; 
     
    public class Provider { 
      
        public static void main(String[] args) throws Exception { 
            ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"applicationContext.xml"}); 
            context.start(); 
      
            System.in.read(); // 为保证服务一直开着,利用输入流的阻塞来模拟 
        } 
      
    } 


服务消费者:
1.通过Spring配置引用远程服务:

 
[html] view plaincopy在CODE上查看代码片派生到我的代码片

    <?xml version="1.0" encoding="UTF-8"?> 
    <beans xmlns="http://www.springframework.org/schema/beans" 
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" 
        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:application name="hehe_consumer" /> 
     
        <!-- 使用zookeeper注册中心暴露服务地址 --> 
        <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> --> 
        <dubbo:registry address="zookeeper://127.0.0.1:2181" /> 
     
        <!-- 生成远程服务代理,可以像使用本地bean一样使用demoService --> 
        <dubbo:reference id="demoService" 
            interface="com.unj.dubbotest.provider.DemoService" /> 
     
    </beans> 


2.加载Spring配置,并调用远程服务:
调用结果为:


dubbo管理页面:






应用页面:

文章评论

聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
我是如何打败拖延症的
我是如何打败拖延症的
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
鲜为人知的编程真相
鲜为人知的编程真相
漫画:程序员的工作
漫画:程序员的工作
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
那些争议最大的编程观点
那些争议最大的编程观点
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
如何成为一名黑客
如何成为一名黑客
程序员必看的十大电影
程序员必看的十大电影
一个程序员的时间管理
一个程序员的时间管理
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
10个调试和排错的小建议
10个调试和排错的小建议
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
程序员的鄙视链
程序员的鄙视链
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
程序员应该关注的一些事儿
程序员应该关注的一些事儿
中美印日四国程序员比较
中美印日四国程序员比较
代码女神横空出世
代码女神横空出世
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
程序员和编码员之间的区别
程序员和编码员之间的区别
每天工作4小时的程序员
每天工作4小时的程序员
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
 程序员的样子
程序员的样子
Java程序员必看电影
Java程序员必看电影
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
旅行,写作,编程
旅行,写作,编程
为什么程序员都是夜猫子
为什么程序员都是夜猫子
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
编程语言是女人
编程语言是女人
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有