Dubbo+Zookeeper+Spring整合应用篇-Dubbo基于Zookeeper实现分布式服务

为什么要用dubbo?
 
还是让官方来解释吧:
 
一般 nginx+tomcat
         | ----> Controller1--------->service1
请求----->nginx  |
         |----->Controller2--------->service2
请求进了Controller 就只有一条路可以走了
 
使用dubbo后
              | ------->service1
请求------>Controller---->   |
              |---------->service2
简单的说 也就是 一个Contoller 我可以部署多个 service   。
 
一般的mvc项目 包含 Controller、Servicei、ServiceImpl、dao三层
使用doubbo我们可以把项目拆分:
Controller 作为 “消费着” 一个项目
ServiceImpl +dao 作为 “提供者” 一个项目
Servicei “接口” 可以作为一个项目
我们可以部署多个“提供着”。。。。。。。。。。。。。。。。。。。
 
Zookeeper作为Dubbo服务的注册中心,Dubbo原先基于数据库的注册中心,没采用Zookeeper,Zookeeper一个分布式的服务框架,是树型的目录服务的数据存储,能做到集群管理数据 ,这里能很好的作为Dubbo服务的注册中心,Dubbo能与Zookeeper做到集群部署,当提供者出现断电等异常停机时,Zookeeper注册中心能自动删除提供者信息,当提供者重启时,能自动恢复注册数据,以及订阅请求。我们先在linux上安装Zookeeper,我们安装最简单的单点
Windons 安装Zookeeper
 
1,Zookeeper 官网下载windons 版本,(不会下载百度)
单机安装非常简单,只要获取到 Zookeeper 的压缩包并解压到某个目录如
 
打开目录机构为:
 
 
Zookeeper 的启动脚本在 bin 目录下,Windows 下的启动脚本是 zkServer.cmd。
 
在你执行启动脚本之前,还有几个基本的配置项需要配置一下,Zookeeper 的配置文件在 conf 目录下,这个目录下有 zoo_sample.cfg 和 log4j.properties,你需要做的就是将 zoo_sample.cfg 改名为 zoo.cfg,因为 Zookeeper 在启动时会找这个文件作为默认配置文件。下面详细介绍一下,这个配置文件中各个配置项的意义。
 
打开以后
 
1
2
3
4
5
6
7
8
9
10
11
12
# The number of milliseconds of each tick
tickTime=2000
# The number of ticks that the initial
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
dataDir=/tmp/zookeeper
# the port at which the clients will connect
clientPort=2181

  

  • tickTime:这个时间是作为 Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。
  • dataDir:顾名思义就是 Zookeeper 保存数据的目录,默认情况下,Zookeeper 将写数据的日志文件也保存在这个目录里。
  • clientPort:这个端口就是客户端连接 Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求。
二.dubbo-admin。 dubbo管控台的安装
下载 dubbo-admin-2.5.3.war  
解压之后:
修改 META-INF/dubbo.properties文件
1
2
3
dubbo.registry.address=zookeeper://127.0.0.1:2181
dubbo.admin.root.password=root
dubbo.admin.guest.password=guest

address:zookeeper 的ip地址 后面是端口号  ,和zookeeper中配置的端口号一样

修改完成后需要一个tomcat   打开tomcat     \webapps目录 ,将解压后修改好的所有的dubbo-admin 里的文件复制到 \webapps中,


 

此时我们已经配置好了。现在可以启动tomcat了 (主意:在启动tomcat之前要先启动zookeeper ,启动zookeeper前面有介绍)。 启动tomcat之后 在浏览器输入 http://localhost:8080/dubbo-admin-2.5.3进入dubbo管控台的主页

(备注:使用jdk1.8 tomcat启动可能会出错  有关 URI。。。。 的错误。我最后换成1.7了)


用户名和密码就是dubbo.properties 中配置的 默认的是 用户名 :root, 密码:root 

输入用户名和密码之后 进入首页           

 

 当然现在还没有 消费者 和 提供者 
 
现在我们来开发   消费者  和 提供者
 
 
配置 好 zookeeper之后 搭建 maven+springmvc+dubbo环境
 
新建3个maven项目
1,test-dubbo-provider ,java项目,作为提供者,serviceImpl 和dao 层
2,test-public-interface ,java项目,存放公共的接口 ,servicei        是service的接口  (备注:1要依赖2,  3也要依赖2)
3,test-web-consumer,web项目,存放 Controller 和 页面 
 
首先我们来开发 服务的提供者也就是 test-dubbo-provider ,目录结构为
ApplicationContent-dubbo.xml        dubbo服务的配置文件(名字随意)     (待会再介绍)
ApplicationContent.xml       spring的配置文件
这两个配置文件 必须要放到  MATE-INF/spring/下面 (原因后面再说)
 
UserServiceImpl.java  借口的实现类
在服务提供方实现接口:(对服务消费方隐藏实现)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
package  com.cl.user.serviceImpl;
 
import  org.springframework.stereotype.Service;
 
import  com.cl.user.servicei.UserService;
 
@Service ( "userService" )
public  class  UserServiceImpl  implements  UserService{
 
     @Override
     public  String sayHello() {
         
         System.out.println( "hello world----------------------------" );
         
         return  "hello world" ;
         
     }
}
 
有了 实现类 还需要接口  也就是项目test-public-interface 
定义服务接口:(该接口需单独打包,在服务提供方和消费方共享)
 
 
这个项目很简单 只需要 接口 就行了
1
2
3
4
5
6
package  com.cl.user.servicei;
 
public  interface  UserService {
     public  String sayHello();
 
}

当然 项目 1 要 依赖 项目 2  

所以在1 的 pom.xml 中 有

 

复制代码
1 <dependency>
2             <groupId>test-web</groupId>
3             <artifactId>test-pubilc-interface</artifactId>       加入项目2依赖
4             <version>0.0.1-SNAPSHOT</version>
5             <scope>test</scope>
6 </dependency>
复制代码

那么 1 中的 UserServiceImpl 就可以实现 UserService接口

 当然我们用到 dubbo 就要有dubbo的核心jar包   所以在1 的 pom.xml 中 有
1 <dependency>
2     <groupId>com.alibaba</groupId> 
3     <artifactId>dubbo</artifactId>
4     <version>2.5.3</version>
5 </dependency>

还要有 zookeeper的  所以在1 的 pom.xml 中 有

1 <dependency>
2         <groupId>org.apache.zookeeper</groupId>
3         <artifactId>zookeeper</artifactId>
4         <version>3.3.3</version>
5 </dependency>

下面介绍一下项目1 中 的 ApplicationContent-dubbo.xml   和  ApplicationContent.xml 

 
ApplicationContent.xml  主要是spring的配置 不多说。
1 <!-- 启动组件扫描,排除@Controller组件,该组件由SpringMVC配置文件扫描 -->
2     <context:component-scan base-package="com.cl.user.serviceImpl"/>

ApplicationContent-dubbo.xml   dubbo服务的配置

spring配置声明暴露服务:

 
复制代码
 1     <!-- 提供方应用信息,用于计算依赖关系 -->
 2     <dubbo:application name="hehe_provider" />
 3     <!-- 使用zookeeper注册中心暴露服务地址   端口是zookeeper 中配置的2181-->
 4     <dubbo:registry address="zookeeper://127.0.0.1:2181"/>
 5     <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
 6     <!-- 用dubbo协议在20880端口暴露服务 -->
 7     <dubbo:protocol name="dubbo" port="20880" />
 8     <!-- 具体的实现bean -->
 9     <bean id="userService" class="com.cl.user.serviceImpl.UserServiceImpl" />
10     <!-- 声明需要暴露的服务接口 -->
11     <dubbo:service interface="com.cl.user.servicei.UserService" ref="userService" />
复制代码

 主意:有可能你的配置文件中不识别 <dubbo:>  去网上找解决的办法

 

到这里我们的  “提供者” 即 服务   已经开发完了,那么如何启动服务呢?  在项目1中有个start.Java 

复制代码
 1 package com.test;
 2 
 3 import org.apache.log4j.PropertyConfigurator;
 4 
 5 public class start {
 6      static{  
 7             PropertyConfigurator.configure("src/main/resources/log4j.properties");  
 8         }  
 9     public static void main(String[] args) {
10         
11         com.alibaba.dubbo.container.Main.main(args);
12     }
13 }
复制代码

 主意里面有main方法,可以直接运行启动了。别急!!! 之前还有个问题就是为什   ApplicationContent-dubbo.xml   和  ApplicationContent.xml    这两个配置文件 必须要放到 /MATE-INF/spring/下面

因为  com.alibaba.dubbo.Container.Main.main(args)  默认就会去加载 /MATE-INF/spring/ 下的配置文件

我们来看一下源码

 看完源码 这下明白为什么了吧!!!!!!!!!!!!!!!!!
 
启动服务后  我们在 dubbo-admin中就能看到我们刚才开发的的  “提供者”
 
 
 
192.168.56.1 是本地局域网 地址
 
这是 “提供者”  此时还没有“消费者”   接下来我们就要开发 “消费者”
 
test-web-consumer   
 
 
UserController.java
复制代码
@Controller
public class UserController {
    
    @Resource(name="userService")
    private UserService userService;
    
    
    @RequestMapping("/hello/test/world")
    public void sayHello(){
        System.out.println(userService.sayHello()+"**************************");
    }
}
复制代码

ApplicationContext-mvc.xml 都是springmvc的配置 如下不解释了

复制代码
<mvc:annotation-driven/>
    <mvc:default-servlet-handler/>
    <context:component-scan base-package="com" />
    
    
    <!-- 对静态资源文件的访问  restful-->     
    <mvc:resources mapping="/js/**" location="/js/" />
    <mvc:resources mapping="/lib/**" location="/lib/" />
    <mvc:resources mapping="/plugins/**" location="/plugins/" />
    <mvc:resources mapping="/uploadFiles/**" location="/uploadFiles/" /> 
    <mvc:resources mapping="/WEB-INF/html/**" location="/WEB-INF/html/" /> 
     
    <!-- 配置SpringMVC的视图解析器 -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/html"/>
        <property name="suffix" value=".jsp"/>
    </bean>
    
    <!-- 上传拦截,如最大上传值及最小上传值 -->
      <bean id="multipartResolver"   class="org.springframework.web.multipart.commons.CommonsMultipartResolver" >   
          <property name="maxUploadSize">    
              <value>104857600</value>    
           </property>   
            <property name="maxInMemorySize">    
                <value>4096</value>    
            </property>   
             <property name="defaultEncoding">    
                <value>utf-8</value>    
            </property> 
    </bean>  
复制代码

ApplicationContext-dubbo.xml

服务消费者

 

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


复制代码
<?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-2.5.xsd
    http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">

    <!-- 消费方应用名,用于计算依赖关系,不是匹配条件,不要与提供方一样 -->  
    <dubbo:application name="hehe_consumer" />  
  
    <!-- 使用zookeeper注册中心暴露服务地址 -->  
   
     <dubbo:registry address="zookeeper://127.0.0.1:2181" /> 
    
    <!-- 组播注册 -->
   <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
  
    <!-- 生成远程服务代理,可以像使用本地bean一样使用userService -->  
    <dubbo:reference id="userService"    interface="com.cl.user.servicei.UserService" />
</beans>
复制代码

 开发完消费者后 ,启动消费者,可以在管控台看到

 

 完了!!      Dubbo更多详细的东西还去官网的用户手册寻找吧!!   http://dubbo.io/User+Guide-zh.htm    http://dubbo.io/    用户手册说的挺详细的!这里仅供参考!
 

优点:

    服务提供者和服务消费者只需要知道注册中心即可,它们之间打交道需通过注册中心这个第三方,只要是注册中心中已经注册的服务,我们均可以使用,实现了服务提供者和服务消费者间的解耦。


最后 ,在开发的时候为了方便,我们可以使用组播注册!
 <!-- 组播注册 -->
   <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
 源码:
 https://github.com/KellyLChen/Dubbo.git
 
 
 
作者原创转载请说明: http://www.cnblogs.com/c9999/p/6019307.html
综合另一个帖子:http://blog.csdn.net/hejingyuan6/article/details/47403299
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Dubbo是一个高性能的Java RPC框架,它提供了分布式服务框架的支持,可以让开发者轻松地构建分布式应用。而Zookeeper是一个分布式的协调服务,它可以用来管理和协调分布式系统中的各种资源,如配置信息、命名服务、分布式锁等。 当使用Dubbo框架时,我们可以将服务注册到Zookeeper中,这样其他的服务消费者就可以通过Zookeeper来发现和调用这些服务。同时,Zookeeper还可以用来监控服务的状态,当服务出现故障时,Zookeeper可以及时地通知其他服务消费者,从而保证整个分布式系统的稳定性和可靠性。 因此,DubboZookeeper的结合可以为分布式系统的开发和运维提供很好的支持,让开发者可以更加轻松地构建高性能、可靠的分布式应用。 ### 回答2: DubboZookeeper是两个分布式框架,结合起来可以帮助开发者构建高性能、高可用性的分布式应用Dubbo提供了RPC远程过程调用框架,可以实现跨进程、跨语言的方法调用,支持负载均衡、容错、限流等特性。而Zookeeper是一个开源的分布式协调服务框架,可以协调和管理分布式应用的节点之间的通信。下面详细介绍DubboZookeeper的分布式基础。 1、Dubbo Dubbo是一款高性能、轻量级的RPC框架,采用Java编写,支持多种协议(Dubbo协议、HTTP、Hessian、RMI等),通过注册中心连接提供者和消费者。Dubbo可以做到请求耗时的优化、负载均衡、集群容错、异步调用等特性,让开发者可以轻松地构建分布式应用Dubbo的工作流程如下:服务提供者(Provider)将服务注册到注册中心,服务消费者(Consumer)从注册中心订阅服务,当服务消费者需要调用服务时,会通过代理对象来远程调用服务提供者,完成方法调用并将结果返回。Dubbo自带了多种注册中心的实现,例如Zookeeper、Redis等。 2、Zookeeper Zookeeper是一个开源的分布式协调服务框架,可以用来协调和管理分布式应用的节点之间的通信。Zookeeper的主要作用是提供一个分布式的协调服务,例如分布式锁、配置管理、分布式队列等。Zookeeper可以减轻分布式应用的复杂性,让开发者可以专注于业务逻辑。 Zookeeper通过基于目录树结构的数据模型来保存数据,并提供了一套完整的API用于操作这些数据。Zookeeper的工作原理是基于主从架构,当Zookeeper集群中的节点出现故障时,可以自动选举出新的Leader节点以继续提供服务。 DubboZookeeper结合起来可以构建一个高可用性的分布式应用Dubbo将服务注册到Zookeeper,服务消费者从Zookeeper订阅服务,同时Zookeeper提供了注册中心的高可用性和负载均衡等特性。当服务提供者出现故障时,Zookeeper可以自动重新分配服务提供者的角色,从而保证服务的高可用性。 ### 回答3: DubboZookeeper是目前流行的分布式系统基础组件,它们常常被一起使用来构建可靠的分布式服务。在现代复杂的分布式系统中使用基础组件可以极大地简化开发和部署工作,而测试和维护都变得更容易。 Dubbo是一种高性能的分布式服务框架,它提供了统一的服务管理和RPC调用机制。Dubbo的核心在于将服务提供方和服务消费方解耦,同时提供了动态负载均衡和服务治理等功能。Dubbo具有高性能、可靠、易扩展等优点,广泛应用于大型分布式系统中。 Zookeeper是一种开源的分布式配置管理和协调解决方案,可以实现分布式配置管理、命名服务、分布式锁、集群选主和消息队列等功能。Zookeeper具有高可用性、可靠性和易扩展性,可以轻松管理大型分布式系统的配置和状态信息。Zookeeper还提供了建立分布式协调基础设施的基础组件。 在实际应用中,Dubbo通常和Zookeeper一起使用。服务提供方将服务注册到Zookeeper中心,服务消费方从Zookeeper中获取服务地址,并进行RPC调用,通过Dubbo提供的高性能、高可靠性的RPC调用机制实现分布式服务的调用和管理。 总之,DubboZookeeper是分布式系统基础构件,通常会共同使用来实现高性能、高可靠性的分布式服务。对于分布式开发者来说,掌握这些基础组件的使用和原理,可以对分布式开发和维护提供很大帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值