文档章节

集成Dubbo服务(Spring)

d
 djflajlkfd
发布于 2016/05/15 23:25
字数 1235
阅读 15
收藏 1
点赞 3
评论 1

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 plain copy

 在CODE上查看代码片派生到我的代码片

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

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

 

[java] view plain copy

 在CODE上查看代码片派生到我的代码片

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


用Spring配置声明暴露服务:

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

[html] view plain copy

 在CODE上查看代码片派生到我的代码片

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

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

消费者部分

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

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

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

[html] view plain copy

 在CODE上查看代码片派生到我的代码片

  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 plain copy

 在CODE上查看代码片派生到我的代码片

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

 

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

Maven,Springmvc mybatis shiro, Druid, Restful, Dubbo, ZooKeeper,Redis,FastDFS,ActiveMQ,Nginx 
1.     项目核心代码结构截图

分布式框架介绍 - kafkaee - kafkaee的博客

   项目模块依赖分布式框架介绍 - kafkaee - kafkaee的博客

特别提醒:开发人员在开发的时候可以将自己的业务REST服务化或者Dubbo服务化

2.    项目依赖介绍

   2.1 后台管理系统、Rest服务系统、Scheculer定时调度系统依赖如下图:
 

分布式框架介绍 - kafkaee - kafkaee的博客

       2.2 Dubbo独立服务项目依赖如下图:

 分布式框架介绍 - kafkaee - kafkaee的博客

3.  项目功能部分截图:

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客
 

zookeeper、dubbo服务启动 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客
 

dubbo管控台 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 REST服务平台

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 

分布式框架介绍 - kafkaee - kafkaee的博客

 评论这张

 

© 著作权归作者所有

共有 人打赏支持
d
粉丝 0
博文 11
码字总数 34899
作品 0
东城
加载中

评论(1)

d
djflajlkfd
Maven,Springmvc mybatis shiro, Druid, Restful, Dubbo, ZooKeeper,Redis,FastDFS,ActiveMQ,Nginx
1. 项目核心代码结构截图
分布式框架介绍 - kafkaee - kafkaee的博客
项目模块依赖
分布式框架介绍 - kafkaee - kafkaee的博客
特别提醒:开发人员在开发的时候可以将自己的业务REST服务化或者Dubbo服务化

2. 项目依赖介绍

2.1 后台管理系统、Rest服务系统、Scheculer定时调度系统依赖如下图:

分布式框架介绍 - kafkaee - kafkaee的博客

2.2 Dubbo独立服务项目依赖如下图:
分布式框架介绍 - kafkaee - kafkaee的博客

3. 项目功能部分截图:
分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

zookeeper、dubbo服务启动
分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

dubbo管控台
分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍 - kafkaee - kafkaee的博客
REST服务平台
分布式框架介绍 - kafkaee - kafkaee的博客

分布式框架介绍
微服务选择Spring Cloud还是Dubbo?

点击关注 异步图书,置顶公众号 每天与你分享 IT好书 技术干货 职场知识 参与文末话题讨论,每日赠送异步图书。 ——异步小编 在阿里巴巴的生态中,微服务逐渐成为主要的服务形态,伴随着容器...

异步社区 ⋅ 04/27 ⋅ 0

Dubbo 的 Swagger 服务文档 - swagger-dubbo

swagger-dubbo支持dubbo以swagger方式展示文档和rest风格的HTTP模拟测试,主要应用场景有以下几点: 通过dubbo与swagger的集成,提供接口文档的阅读 开发人员可以用它来自测服务接口,也可以...

Sayi ⋅ 06/07 ⋅ 0

【开源访谈】刘军:无需“二选一”,Dubbo 将积极适配 Spring Cloud 生态

曾风靡国内的开源 RPC 服务框架 Dubbo 在重启维护后,令许多用户为之雀跃,但同时,也迎来了一些质疑的声音。互联网技术发展迅速,Dubbo 是否还能跟上时代?Dubbo 与 Spring Cloud 相比又有何...

王练 ⋅ 01/08 ⋅ 17

dubbo+zookeeper+maven+idea2016分布式服务框架搭建步骤

1、首先在idea中创建一个多模块应用,为了工程的干净整洁,web工程最好只集成了springmvc和spring的web应用,service工程最好只集成了spring。 2、配置dubbo服务提供者 2.1、服务器提供者web...

城里的月光 ⋅ 2016/11/18 ⋅ 0

m.toutiao.im/whatsmars

whatsmars $ Java生态研究(Spring Boot + Redis + Dubbo + RocketMQ) Spring Boot 系列(Servlet, Tomcat, Spring, SpringMVC, Spring Boot) Modules intro Module Intro whatsmars-common m......

m.toutiao.im ⋅ 2017/12/25 ⋅ 0

SpringBoot bean注入失败

使用springboot+zookeeper+dubbo开发分布式应用 provider.xml

ysjO ⋅ 04/23 ⋅ 0

dubbo使用入门-使用zookeeper注册

关于dubbo的使用,在dubbo的apache官网上其实说的很清楚了,在这里只是记录一下dubbo使用zookeeper作为注册中心的使用例子,简要分析了一下dubbo使用zookeeper的命名服务进行注册的外在表现。...

峡客 ⋅ 06/10 ⋅ 0

【Spring Cloud】分布式必学springcloud(一)——简介和看法

一、前言 开篇之前,我想说,springcloud会完胜dubbo。 小编以前做分布式是用的webservice、dubbo。最近的项目中,开始使用了springcloud,springcloud包含了很多的组件,这些组件是dubbo没有...

kisscatforever ⋅ 04/16 ⋅ 0

通过dubbo暴露接口调用方法,及基于zookeeper的dubbo涉及配置文件【转】

现在很流行的Dubbo很多朋友都听说过吧,最近我也在看这方面的东西,分享先我的心得笔记。 先说说我们团队要做的项目框架,很简单重在实现基于zookeeper的dubbo注册。 框架:springmvc+sprin...

如何让他和 ⋅ 2016/10/25 ⋅ 1

通过dubbo暴露接口调用方法,及基于zookeeper的dubbo涉及配置文件【转】

现在很流行的Dubbo很多朋友都听说过吧,最近我也在看这方面的东西,分享先我的心得笔记。 先说说我们团队要做的项目框架,很简单重在实现基于zookeeper的dubbo注册。 框架:springmvc+sprin...

结构好可 ⋅ 2016/10/18 ⋅ 1

没有更多内容

加载失败,请刷新页面

加载更多

下一页

用ZBLOG2.3博客写读书笔记网站能创造今日头条的辉煌吗?

最近两年,著名的自媒体网站今日头条可以说是火得一塌糊涂,虽然从目前来看也遇到了一点瓶颈,毕竟发展到了一定的规模,继续增长就更加难了,但如今的今日头条规模和流量已经非常大了。 我们...

原创小博客 ⋅ 40分钟前 ⋅ 0

MyBatis四大核心概念

本文讲解 MyBatis 四大核心概念(SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession、Mapper)。 MyBatis 作为互联网数据库映射工具界的“上古神器”,训有四大“神兽”,谓之:Sql...

waylau ⋅ 今天 ⋅ 0

以太坊java开发包web3j简介

web3j(org.web3j)是Java版本的以太坊JSON RPC接口协议封装实现,如果需要将你的Java应用或安卓应用接入以太坊,或者希望用java开发一个钱包应用,那么用web3j就对了。 web3j的功能相当完整...

汇智网教程 ⋅ 今天 ⋅ 0

2个线程交替打印100以内的数字

重点提示: 线程的本质上只是一个壳子,真正的逻辑其实在“竞态条件”中。 举个例子,比如本题中的打印,那么在竞态条件中,我只需要一个方法即可; 假如我的需求是2个线程,一个+1,一个-1,...

Germmy ⋅ 今天 ⋅ 0

Springboot2 之 Spring Data Redis 实现消息队列——发布/订阅模式

一般来说,消息队列有两种场景,一种是发布者订阅者模式,一种是生产者消费者模式,这里利用redis消息“发布/订阅”来简单实现订阅者模式。 实现之前先过过 redis 发布订阅的一些基础概念和操...

Simonton ⋅ 今天 ⋅ 0

error:Could not find gradle

一.更新Android Studio后打开Project,报如下错误: Error: Could not find com.android.tools.build:gradle:2.2.1. Searched in the following locations: file:/D:/software/android/andro......

Yao--靠自己 ⋅ 昨天 ⋅ 0

Spring boot 项目打包及引入本地jar包

Spring Boot 项目打包以及引入本地Jar包 [TOC] 上篇文章提到 Maven 项目添加本地jar包的三种方式 ,本篇文章记录下在实际项目中的应用。 spring boot 打包方式 我们知道,传统应用可以将程序...

Os_yxguang ⋅ 昨天 ⋅ 0

常见数据结构(二)-树(二叉树,红黑树,B树)

本文介绍数据结构中几种常见的树:二分查找树,2-3树,红黑树,B树 写在前面 本文所有图片均截图自coursera上普林斯顿的课程《Algorithms, Part I》中的Slides 相关命题的证明可参考《算法(第...

浮躁的码农 ⋅ 昨天 ⋅ 0

android -------- 混淆打包报错 (warning - InnerClass ...)

最近做Android混淆打包遇到一些问题,Android Sdutio 3.1 版本打包的 错误如下: Android studio warning - InnerClass annotations are missing corresponding EnclosingMember annotation......

切切歆语 ⋅ 昨天 ⋅ 0

eclipse酷炫大法之设置主题、皮肤

eclipse酷炫大法 目前两款不错的eclipse 1.系统设置 Window->Preferences->General->Appearance 2.Eclipse Marketplace下载【推荐】 Help->Eclipse Marketplace->搜索‘theme’进行安装 比如......

anlve ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部