Dubbo简单小例子(结合spring)

Dubbo是什么?

Dubbo是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000+个服务提供3,000,000,000+次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

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

其核心部分包含:

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

Dubbo能做什么?

  • 透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。
  • 软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。
  • 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

Spring集成

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

Provider部分

新建一个Web工程 ,导入以下包:

新建一个DemoService.java类,提供者和消费者都要有这个Service,

[java] view plaincopy

  1. package com.znn.provider;
  2. public interface DemoService {
  3. String sayHello(String name);
  4. }

新建一个服务提供方实现接口,对服务消费方隐藏实现

DemoServiceImpl.java

[java] view plaincopy

  1. package com.znn.provider;
  2. public class DemoServiceImpl implements DemoService{
  3. @Override
  4. public String sayHello(String name) {
  5. return "Hello Dubbo,Hello " + name;
  6. }
  7. }

用Spring配置声明暴露服务:

新建一个dubbo-provider.xml文件对dubbo进行配置:

[html] view plaincopy

  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"
  4. xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
  5. xsi:schemaLocation="http://www.springframework.org/schema/beans
  6. http://www.springframework.org/schema/beans/spring-beans.xsd
  7. http://code.alibabatech.com/schema/dubbo
  8. http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
  9. <!-- 提供方应用信息,用于计算依赖关系 -->
  10. <dubbo:application name="hello-world-app"  />
  11. <!-- 使用multicast广播注册中心暴露服务地址 -->
  12. <!--  <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
  13. <!-- 使用zookeeper注册中心暴露服务地址 -->
  14. <dubbo:registry address="zookeeper://115.28.189.59:2181" />
  15. <!-- 用dubbo协议在20880端口暴露服务 -->
  16. <dubbo:protocol name="dubbo" port="20880" />
  17. <!-- 声明需要暴露的服务接口 -->
  18. <dubbo:service interface="com.znn.provider.DemoService" ref="demoService" />
  19. <!-- 和本地bean一样实现服务 -->
  20. <bean id="demoService" class="com.znn.provider.DemoServiceImpl" />
  21. </beans>

注:有两种暴露地址的方法,广播的那个在测试消费者的时候没有成功,就自己搭了一个zookeeper,使用zookeeper来管理。

消费者部分

另外新建一个工程:znn-service-consumer

导入第三方包,和提供者一样。另外可以把提供者打成一个Jar,在消费者部分添加,如果用的是Eclipse并且提供者和消费者在同一个workplace下,可以直接通过右键->propertities->Java Build Path->Project->Add来添加。

新建一个dubbo-consumer.xml,对dubbo进行配置:

[html] view plaincopy

  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"
  4. xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
  5. xsi:schemaLocation="http://www.springframework.org/schema/beans
  6. http://www.springframework.org/schema/beans/spring-beans.xsd
  7. http://code.alibabatech.com/schema/dubbo
  8. http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
  9. <!-- 消费方应用名,用于计算依赖关系,不是匹配条件,不要与提供方一样 -->
  10. <dubbo:application name="consumer-of-helloworld-app"/>
  11. <!-- 使用multicast广播注册中心暴露发现服务地址 -->
  12. <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
  13. <dubbo:registry address="zookeeper://115.28.189.59:2181" />
  14. <!-- 生成远程服务代理,可以和本地bean一样使用demoService -->
  15. <dubbo:reference id="demoService" interface="com.znn.provider.DemoService" />
  16. </beans>

新建一个测试类,当然具体用的时候会写一个专门的类使用IOC注入:

[java] view plaincopy

  1. package com.znn.consumer;
  2. import org.springframework.context.support.ClassPathXmlApplicationContext;
  3. import com.znn.provider.DemoService;
  4. public class Consumer {
  5. public static void main(String[] args) {
  6. ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("file:D:/develop/myeclipsework/znn-service-consumer/WebRoot/WEB-INF/dubbo-consumer.xml");
  7. context.start();
  8. DemoService demoService = (DemoService)context.getBean("demoService"); // 获取远程服务代理
  9. String hello = demoService.sayHello("world"); // 执行远程方法
  10. System.out.println(hello);
  11. }
  12. }

先运行提供者,然后运行消费者:

源码:https://github.com/qduningning/DubboDemo/

时间: 2024-10-10 22:54:30

Dubbo简单小例子(结合spring)的相关文章

ASP.NET Cookie对象到底是毛啊?(简单小例子)

记得刚接触asp.net的时候,就被几个概念搞的头痛不已,比如Request,Response,Session和Cookie.然后还各种在搜索引擎搜,各种问同事的,但是结果就是自己还是很懵的节奏. 那cookie到底是毛啊?下面是我最不喜欢的一种解释方式(官方定义吧应该叫,我这种智商根本读不懂嘛~) Cookie对象也称缓存对象,该对象用于保存客户端浏览器请求的服务器页面,也可用它存放非敏感性的用户信息. 以前根本读不懂啊,现在其实也懵懵的. 还是用例子能把这个概念搞明白 1.做一个用户登录的界

javascript 面向对象写法的简单小例子,方面以后参考

面向对象写法的简单小例子,也即是一个小模板,方便以后拿来参考,如果有误,请各位大神多多指点.思想:主要给#box添加颜色和添加内容,一个方法是添加颜色,另一个方法是添加内容,然后编写的面向对象写法. <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <st

php+jquery+ajax+json简单小例子

直接贴代码: Php代码: <html> <title>php+jquery+ajax+json简单小例子</title> <?php header("Content-Type:text/html;charset=utf-8"); ?> <head> <script type="text/javascript" src="http://code.jquery.com/jquery.min.j

详细解读SearchView(一)—— 简单小例子

这次开的是一个讲解SearchView的栏目,第一篇主要是给一个小例子,让大家对这个搜索视图有一个了解,之后再分布细化来说. 目标: 我们先来定个目标,我们通过搜索框来输入要搜索的联系人名字,输入的时候下面的listview就展现出候选的人. 思路: 1.要得到联系人数据,就需要有访问联系人的权限 2.必须通过ContentResolver来得到操作联系人名单的指针 3.每次输入一个字的时候就应该触发一次搜索,并且能将搜索的结果展示出来 4.既然要进行搜索,那么就要用到SQL语句 实现: 1.

自定义View简单小例子

在开发过程中,尽管Android系统提供了非常多的控件给我们使用,但是还是不能满足我们人类的需求,感觉我们确实在贪婪了,呵呵!这个时候,我们可能就要用到自定义控件,以及自定义属性,应该怎么操作呢? 一般要按照以下几个步骤来操作: 1,继承View或其它控件,重写构造函数onDraw,onMeasure,onTouch等函数. 2,自定义属性的话,就需要在values下建立attrs.xml,在其中定义你需要的属性,详细的属性类型可以参考文章http://www.jb51.net/article/

关于ExpandableListView用法的一个简单小例子

喜欢显示好友QQ那样的列表,可以展开,可以收起,在android中,以往用的比较多的是listview,虽然可以实现列表的展示,但在某些情况下,我们还是希望用到可以分组并实现收缩的列表,那就要用到android的ExpandableListView,今天研究了一下这个的用法,也参考了很多资料动手写了一个小demo,实现了基本的功能,但界面优化方面做得还不够好,有待改进,素材采用了Q版三国杀武将的图片,很有爱哈哈,下面直接上效果图以及源代码~!                     main.x

【小知识】小例子说明Spring的核心思想之一:控制反转。

装饰设计模式:使用频率很高!!! 目的:改写已存在的类的某个方法或某些方法,使方法增强了.装饰设计模式(也即包装设计模式) 口诀: 1.编写一个类,实现与被包装类相同的接口.(这样他们就具备了相同的行为) 2.定义一个被包装类类型的变量,即引用,用于接收被包装的对象. 3.定义构造方法,把被包装类的对象注入,给被包装类变量赋值.(因为后面我要用该包装类的对象,所以要注入进来) 4.对于需要改写的方法,写自己的代码.(若重写方法的时候,还需要用到其他类的对象,那我们就在构造方法中继续注入即可) 5

从一个简单的例子看spring ApplicationContext上下文隔离

前言 某天,浏览博客园的时候,对首页上面的一篇文章,标题为:<<一个普通类就能干趴你的springboot,你信吗?>>,文章链接:https://www.cnblogs.com/rongdi/p/11780204.html#4414216 很是感兴趣.点进去之后,大致看一下.该篇博文主要说的是在使用spring boot环境下想创建一个名为Environment的bean,结果发现创建不了,于是不断调试终于找到了“真理”. 说真的.这篇博文的内容非常长,主要也是记录调试过程的“流

FragmentTabHost简单小例子

Tab页面的布局R.layout.tabhost_layout: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match