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:\Tools\zookeeper\zookeeper-3.4.5\bin,

双击zkServer.cmd启动注册中心服务。

定义服务接口:

  1. package com.liangbinny.dubbotest.provider;
  2. import java.util.List;
  3. import com.liangbinny.dubbotest.provider.impl.User;
  4. public interface DemoService {
  5. String sayHello(String name);
  6. public List<User> getUsers();
  7. }

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

  1. package com.liangbinny.dubbotest.provider.impl;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import com.liangbinny.dubbotest.provider.DemoService;
  5. public class DemoServiceImpl implements DemoService {
  6. public String sayHello(String name) {
  7. return "Hello " + name;
  8. }
  9. public List<User> getUsers() {
  10. List<User> list = new ArrayList<User>();
  11. User user = new User();
  12. user.setAge(28);
  13. user.setName("liangbinny");
  14. list.add(user);
  15. user = new User();
  16. user.setAge(27);
  17. user.setName("binny");
  18. list.add(user);
  19. return list;
  20. }
  21. }

用Spring配置声明暴露服务:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans
  5. http://www.springframework.org/schema/beans/spring-beans.xsd
  6. http://code.alibabatech.com/schema/dubbo
  7. http://code.alibabatech.com/schema/dubbo/dubbo.xsd
  8. ">
  9. <!-- 具体的实现bean -->
  10. <bean id="demoService" class="com.liangbinny.dubbotest.provider.impl.DemoServiceImpl" />
  11. <!-- 提供方应用信息,用于计算依赖关系 -->
  12. <dubbo:application name="dubbo_provider" />
  13. <!-- 使用multicast广播注册中心暴露服务地址 <dubbo:registry address="multicast://224.5.6.7:1234"
  14. /> -->
  15. <!-- 使用zookeeper注册中心暴露服务地址 -->
  16. <dubbo:registry address="zookeeper://10.102.30.211:2181" />
  17. <!-- 用dubbo协议在20880端口暴露服务 -->
  18. <dubbo:protocol name="dubbo" port="20880" />
  19. <!-- 声明需要暴露的服务接口 ,对应的具体实现类是自定义bean:demoService -->
  20. <dubbo:service interface="com.liangbinny.dubbotest.provider.DemoService" ref="demoService" />
  21. </beans>

加载Spring配置,启动服务:

  1. package com.liangbinny.dubbotest.provider.impl;
  2. import org.springframework.context.support.ClassPathXmlApplicationContext;
  3. public class Provider {
  4. public static void main(String[] args) {
  5. ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] { "applicationContext.xml" });
  6. context.start();
  7. // 为保证服务一直开着,一直循环等待
  8. synchronized (Provider.class) {
  9. while (true) {
  10. try {
  11. Provider.class.wait();
  12. } catch (Throwable e) {
  13. }
  14. }
  15. }
  16. }
  17. }

整个服务端的项目图如下:

服务端开发好后,提供对应的jar包给消费端,提供对应的接口。

导出服务端项目为jar包即可。

新建消费端项目,依赖的jar包有:

其中包括刚刚导出的dubbo-server.jar包

服务消费者:

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

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans
  5. http://www.springframework.org/schema/beans/spring-beans.xsd
  6. http://code.alibabatech.com/schema/dubbo
  7. http://code.alibabatech.com/schema/dubbo/dubbo.xsd
  8. ">
  9. <!-- 消费方应用名,用于计算依赖关系,不是匹配条件,不要与提供方一样 -->
  10. <dubbo:application name="dubbo_consumer" />
  11. <!-- 使用zookeeper注册中心暴露服务地址 -->
  12. <dubbo:registry address="zookeeper://10.102.30.211:2181" />
  13. <!-- 生成远程服务代理,可以像使用本地bean一样使用demoService -->
  14. <dubbo:reference id="demoService" interface="com.liangbinny.dubbotest.provider.DemoService" />
  15. </beans>

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

  1. package com.liangbinny.dubbotest.consumer;
  2. import java.util.List;
  3. import org.springframework.context.support.ClassPathXmlApplicationContext;
  4. import com.liangbinny.dubbotest.provider.DemoService;
  5. import com.liangbinny.dubbotest.provider.impl.User;
  6. public class Consumer {
  7. public static void main(String[] args) {
  8. ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] { "applicationContext.xml" });
  9. context.start();
  10. DemoService demoService = (DemoService) context.getBean("demoService");
  11. String hello = demoService.sayHello("tom");
  12. System.out.println(hello);
  13. List<User> list = demoService.getUsers();
  14. System.out.println(list);
  15. }
  16. }

调用结果

1、下载dubbo控制台管理war包

http://download.csdn.net/detail/liweifengwf/7784901

官方地址:http://code.alibabatech.com/mvn/releases/com/alibaba/dubbo-admin/2.4.1/dubbo-admin-2.4.1.war(这个地址我一直下不了,wget也不通)

下载绿色版tomcat,并解压,删掉apache-tomcat-6.0.37\webapps\ROOT文件夹下的内容,并将dubbo-admin-2.4.1.war解压后,解压出的文件放在ROOT文件夹下

修改apache-tomcat-6.0.37\webapps\ROOT\WEB-INF下的dubbo.properties文件的zookeeper地址

dubbo.registry.address=zookeeper://10.102.30.211:2181
dubbo.admin.root.password=root
dubbo.admin.guest.password=guest

2、启动

先启动zookeeper,再启动tomcat

访问:

http://localhost:8080

登录密码默认是:root/root

可以看到控制台管理界面,

这时候可以启动上篇文章中的提供者和消费者,再在dubbo管理控制台界面可以看到

提供者

消费者

Zookeeper单机配置:

<dubbo:registryaddress="zookeeper://10.20.153.10:2181"/>

Or:

<dubbo:registryprotocol="zookeeper"address="10.20.153.10:2181"/>



Zookeeper集群配置:

<dubbo:registryaddress="zookeeper://10.20.153.10:2181?backup=10.20.153.11:2181,10.20.153.12:2181"/>

Or:

<dubbo:registryprotocol="zookeeper"address="10.20.153.10:2181,10.20.153.11:2181,10.20.153.12:2181"/>

同一Zookeeper,分成多组注册中心:

<dubbo:registryid="chinaRegistry"protocol="zookeeper"address="10.20.153.10:2181"group="china"/>
<dubbo:registryid="intlRegistry"protocol="zookeeper"address="10.20.153.10:2181"group="intl"/>

 

dubbo使用方法的更多相关文章

  1. dubbo接口方法重载且入参未显式指定序列化id导致ClassCastException分析

    问题描述&模拟 线上登录接口,通过监控查看,有类型转换异常,具体报错如下图 此报错信息是dubbo consumer端显示,且登录大部分是正常,有少量部分会报类型转换异常,同事通过更换方法名+ ...

  2. dubbo main方法启动

    public static void main(String[] args) { com.alibaba.dubbo.container.Main.main(args); } 以上就可以简单本地启动了

  3. 基于SOA分布式架构的dubbo框架基础学习篇

    以需求用例为基,抽象接口,Case&Coding两条线并行,服务(M)&消费(VC)分离,单元.接口.功能.集成四层质量管理,自动化集成.测试.交付全程支持. 3个大阶段(需求分析阶段 ...

  4. dubbo 配置解析

    1.dubbo 常用配置 <dubbo:service/> 服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心.eg.<dub ...

  5. dubbo 配置文件详解

    一.dubbo常用配置 <dubbo:service/> 服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心. eg.<dub ...

  6. zookeeper,dubbo,dubbo admin

    zookeeper 1. 分布式协调服务:我们的程序运行在不同的机器上,这些机器可能位于同一个机架,同一个机房又或不同的数据中心.在这样的环境中,我们要实现协调该怎么办?那么这就是分布式协调服务要干的 ...

  7. dubbo(转载)

    1. Dubbo是什么? Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案.简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需 ...

  8. Dubbo框架

    1. Dubbo是什么? Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案.简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需 ...

  9. 最近项目用到Dubbo框架,临时抱佛脚分享一下共探讨。

    1. Dubbo是什么? Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案.简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需 ...

随机推荐

  1. 服务器部署_nginx报错: [warn] conflicting server name "www.test.com" on 0.0.0.0:80, ignored

    今天修改nginx配置文件nginx.conf之后,启动nginx就会报错.经仔细检查是重复配置了 server元素导致, 当nginx检测到重复的 server_name item.test.com ...

  2. 关于安装完Node.js 出现node is not dedined 问题

    今天想来接触下Node.js 神奇  怀着揣揣的心 从官网下载了windows 的64位mis版本  几个下一步就顺利安装完毕了 接着跟着新手教程走  不懂教程里的 苹果shell 是什么 反正就是检 ...

  3. Native Application 开发详解(直接在程序中调用 ntdll.dll 中的 Native API,有内存小、速度快、安全、API丰富等8大优点)

    文章目录:                   1. 引子: 2. Native Application Demo 展示: 3. Native Application 简介: 4. Native Ap ...

  4. JAVA与C++的区别和联系

    这篇总结的貌似不错: http://wenku.baidu.com/link?url=VixkWGl0BzUkmceaDJnQeUhzKEIex6poGaKKvMTP87P8a7HTmS5uIi87I ...

  5. Android开发之PackageManager类

    PackageManger,可以获取到手机上所有的App,并可以获取到每个App中清单文件的所有内容. 设置应用程序版本号在应用程序的manifest文件中定义应用程序版本信息.2个必须同时定义的属性 ...

  6. 【 D3.js 选择集与数据详解 — 2 】 使用data()绑定数据

    D3 中绑定数据大多是由 data() 函数来完成的,它是怎样工作的,它与 datum() 有什么区别呢? data()函数能够将数组各项分别绑定到各元素上,而且能够设置绑定的规则.data()还能够 ...

  7. word 中Sentences、Paragraph等含义和用法

    word 中有Words,Characters,Sentences.Paragraph,Sections 具体含义如下表达式             含义   返回的对象 Words(index)  ...

  8. eclipse 修改设置Ctrl+Shift+F长度

    在window的Preferences中的Java->Code Style->Formatter 到了这一步就是找到Ctrl+Shift+F的格式化模板了,这里不能直接修改.因为是ecli ...

  9. 如何在编译Xcode-Plugin工程的时候增加Cocoapods依赖

    关于如何在编译Xcode-Plugin工程的时候增加Cocoapods依赖 以及在Mac App上使用Cocoapods的时候遇到Library not found for -lPods时的解决办法 ...

  10. ambari安装过程中的问题汇总

    今天重新安装ambari过程中,遇到了几个问题,耗费了我很长时间,在此记录一下 ambari重新安装可参考我之前的一篇随笔 http://www.cnblogs.com/6tian/p/4097401 ...