`
liujiekasini0312
  • 浏览: 147300 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Dubbo zookeeper 初探

 
阅读更多

转:http://blog.csdn.net/u011270461/article/details/12144623

建议参考资料:

http://blog.csdn.net/lin_fs/article/details/7395307

http://blog.csdn.net/goliathray/article/details/8565801

http://zy116494718.iteye.com/blog/1830138

http://agapple.iteye.com/blog/1292473

http://www.open-open.com/news/view/1442a5c

http://code.alibabatech.com/wiki/display/dubbo/Home

http://code.alibabatech.com/wiki/display/dubbo/User+Guide-zh

先把zookeeper在本地给安装好,

安装方法参考:http://blog.csdn.net/wxwzy738/article/details/16330253

这里的话讲述了两个工程一个工程是提供服务的,一个工程是调用服务的,因为dubbo是跟spring进行无缝连接的,故功能配置在spring的配置文件中,跟spring进行整合开发

1、工程是以maven进行构建的,使用的jar包如下:


2、服务提供者的工程

a、dubbo-demo-api 定义接口

  1. publicinterfaceIProcessData{
  2. publicStringdeal(Stringdata);
  3. }
b、dubbo-demo-provider服务提供者

  1. publicclassProcessDataImplimplementsIProcessData{
  2. /*
  3. *@seecom.xxx.bubbo.provider.IProcessData#deal(java.lang.String)
  4. */
  5. @Override
  6. publicStringdeal(Stringdata){
  7. try{
  8. Thread.sleep(1000);
  9. }catch(InterruptedExceptione){
  10. e.printStackTrace();
  11. }
  12. return"Finished:"+data;
  13. }
  14. }

c、applicationProvider.xml配置

  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <beansxmlns="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. <!--Applicationname-->
  10. <dubbo:applicationname="hello-world-app"/>
  11. <!--registryaddress,usedforservicetoregisteritself-->
  12. <dubbo:registryaddress="zookeeper://127.0.0.1:2181"/>
  13. <!--exposethisservicethroughdubboprotocol,throughport20880-->
  14. <!--
  15. <dubbo:protocolname="dubbo"port="20880"/>
  16. <dubbo:protocolname="dubbo"port="9090"server="netty"
  17. client="netty"codec="dubbo"serialization="hessian2"charset="UTF-8"
  18. threadpool="fixed"threads="100"queues="0"iothreads="9"buffer="8192"
  19. accepts="1000"payload="8388608"/>
  20. -->
  21. <!--ServiceinterfaceConcurrentControl-->
  22. <dubbo:serviceinterface="com.huangjie.dubbo_Service.service.IProcessData"
  23. ref="demoService"executes="10"/>
  24. <!--DefaultProtocol-->
  25. <!--
  26. <dubbo:protocolserver="netty"/>
  27. -->
  28. <!--designateimplementation-->
  29. <beanid="demoService"class="com.huangjie.dubbo_Service.service.impl.ProcessDataImpl"/>
  30. </beans>

d、启动服务

  1. publicclassDubboProviderMain{
  2. publicstaticvoidmain(String[]args)throwsException{
  3. ClassPathXmlApplicationContextcontext=newClassPathXmlApplicationContext(
  4. newString[]{"applicationProvider.xml"});
  5. context.start();
  6. System.out.println("Pressanykeytoexit.");
  7. System.in.read();
  8. }
  9. }

3、服务调用者的工程

a、调用类

  1. publicclassConsumerThdimplementsRunnable{
  2. /*
  3. *@seejava.lang.Runnable#run()
  4. */
  5. @Override
  6. publicvoidrun(){
  7. ClassPathXmlApplicationContextcontext=newClassPathXmlApplicationContext(
  8. newString[]{"applicationConsumer.xml"});
  9. context.start();
  10. IProcessDatademoService=(IProcessData)context.getBean("demoService");//get
  11. //service
  12. //invocation
  13. //proxy
  14. Stringhello=demoService.deal("nihao");//doinvoke!
  15. System.out.println(Thread.currentThread().getName()+""+hello);
  16. }
  17. publicstaticvoidmain(String[]args){
  18. newThread(newConsumerThd()).start();
  19. /**
  20. *输出结果:
  21. *Thread-0Finished:nihao
  22. */
  23. }
  24. }

b、applicationConsumer.xml配置

  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <beansxmlns="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. <!--consumerapplicationname-->
  10. <dubbo:applicationname="consumer-of-helloworld-app"/>
  11. <!--registryaddress,usedforconsumertodiscoverservices-->
  12. <dubbo:registryaddress="zookeeper://127.0.0.1:2181"/>
  13. <dubbo:consumertimeout="5000"/>
  14. <!--whichservicetoconsume?-->
  15. <dubbo:referenceid="demoService"interface="com.huangjie.dubbo_Service.service.IProcessData"/>
  16. </beans>
4、最后需要把zookeeper的服务给启动,在zookeeper安装文件夹下面的bin目录里面的zkServer.cmd给点击运行。不要关闭窗口,保持服务运行


这样整个调用就完成了,这样的好处是只要远程提供ip地址及端口号,以及对外调用的类,客户端就可以调用,客户端不必知道服务端的地址之类的

而且服务端可以开多个zookeeper服务,这样如果其中一个zookeeper 服务死掉了,其他服务还能正常运行


工程下载路径:http://download.csdn.net/detail/wxwzy738/6553431

分享到:
评论

相关推荐

    dubbo zookeeper springmvc 集成

    在IT行业中,集成Dubbo、Zookeeper和SpringMVC是一项常见的任务,这三者都是Java生态中的重要组件。本文将详细讲解如何将这三个组件整合在一起,构建一个高效、可扩展的微服务架构。 首先,Dubbo是阿里巴巴开源的一...

    dubbo+zookeeper缓存方案

    Dubbo 和 Zookeeper 结合使用的缓存方案是分布式系统中常见的设计,主要目的是解决多节点环境下数据一致性的问题,确保在各个节点之间的缓存能够实时同步更新。以下将详细阐述这个方案的具体实现、工作原理以及其...

    dubbo zookeeper

    在IT行业中,分布式服务框架是构建大型复杂系统的关键技术之一,Dubbo和Zookeeper就是其中的两个重要组件。本文将详细解析"springmvc+spring+mybatis+dubbo+zookeeper+maven 服务端和消费端实例"这个项目,帮助你...

    dubbo+zookeeper案例,dubbo和Zookeeper详解,Java

    《Dubbo与Zookeeper在分布式环境中的应用解析》 Dubbo和Zookeeper是两个在分布式系统中广泛应用的技术,它们在构建高效、可扩展的服务架构中起着关键作用。本篇文章将深入探讨这两个技术以及如何结合使用,以实现一...

    Spring Boot集成dubbo+zookeeper

    本篇文章将详细探讨如何在Spring Boot项目中集成Dubbo和Zookeeper,以及如何安装和部署最新的Dubbo Admin。 首先,我们需要了解Spring Boot集成Dubbo的基本步骤。在Spring Boot项目中引入Dubbo的支持,我们需要在`...

    dubbo+zookeeper集成搭建

    【集成 dubbo+zookeeper 构建高可用服务框架】 在 IT 领域,服务注册与发现以及服务治理是微服务架构中的关键组成部分。Dubbo 和 ZooKeeper 是两个广泛使用的开源项目,它们分别解决了不同层面的问题。Dubbo 是一款...

    ssm+maven+dubbo+zookeeper分布式架构

    【SSM + Maven + Dubbo + Zookeeper 分布式架构详解】 在当今的互联网时代,分布式架构已经成为大型项目开发的标准配置。SSM、Maven、Dubbo和Zookeeper这四个技术组件是构建高效、可扩展的分布式系统的关键部分。...

    spring dubbo zookeeper实现简单demo

    在IT行业中,Spring Dubbo和Zookeeper是两个非常重要的组件,它们在分布式系统中的应用广泛。本示例将深入解析如何使用Spring Dubbo与Zookeeper共同实现一个简单的服务发现和调用的Demo。 首先,Spring Dubbo是一款...

    dubbo+zookeeper+spring -demo

    这个“dubbo+zookeeper+spring -demo”项目是一个典型的分布式系统架构实践,它展示了如何利用Dubbo构建分布式的微服务,通过Zookeeper实现服务的注册与发现,结合Spring简化服务的管理和调用。这样的架构模式在现代...

    springboot-dubbo-zookeeper完整示例

    《SpringBoot整合Dubbo与Zookeeper的实战解析》 在当今的微服务架构中,SpringBoot因其简洁的配置和快速的开发效率而受到广大开发者喜爱。同时,Dubbo作为一款高性能的服务治理框架,广泛应用于分布式系统中。而...

    dubbo zookeeper 框架整合

    《Dubbo与Zookeeper框架整合详解》 在分布式服务领域,Dubbo和Zookeeper是两个极为重要的组件。Dubbo是一款高性能、轻量级的Java RPC框架,它提供了服务治理、负载均衡、容错机制等功能,极大地提升了微服务架构的...

    dubbo zookeeper ssm项目的整合

    在IT行业中,分布式服务框架是现代企业级应用的重要组成部分,其中Dubbo、Zookeeper和SSM(Spring、SpringMVC、MyBatis)是常见的组件。本篇文章将深入探讨如何将这三个技术进行整合,实现一个高效、可扩展的分布式...

    springboot整合dubbo+zookeeper案例

    在本案例中,我们主要探讨如何将SpringBoot与Dubbo以及Zookeeper进行集成,从而构建一个高可用的服务治理系统。这个系统将利用SpringBoot的简洁性来管理微服务,Dubbo作为服务提供者和服务消费者之间的通信框架,而...

    springboot+dubbo+zookeeper整合

    【SpringBoot + Dubbo + ZooKeeper 整合详解】 在现代企业级开发中,SpringBoot以其简洁的配置和快速的启动特性,成为了构建微服务的首选框架。而Dubbo作为阿里巴巴开源的分布式服务框架,专注于服务治理,为大型...

    springBoot+dubbo+zookeeper分布式微服务

    本项目"springBoot+dubbo+zookeeper分布式微服务"充分利用了这三个组件的优势,构建了一个高效、可扩展且易于维护的服务网络。以下是对这些技术及其整合应用的详细说明: **SpringBoot** SpringBoot是Spring框架的...

    dubbo+zookeeper分布式服务

    【标题】:“Dubbo + ZooKeeper 分布式服务” 【内容】: 在现代软件开发中,分布式服务架构已经成为大型系统设计的重要组成部分。Dubbo 和 ZooKeeper 是两种在分布式环境中广泛使用的开源工具,它们分别承担了...

    spring boot 整合dubbo zookeeper

    本篇将详细介绍如何在 Spring Boot 应用中整合 Dubbo 和 Zookeeper。 首先,我们需要理解 Spring Boot 和 Dubbo 的基本概念。Spring Boot 基于 Spring 框架,简化了配置和启动流程,使得开发者可以更专注于业务逻辑...

    dubbo+zookeeper demo代码和部署说明

    dubbo+zookeeper例子代码和部署说明,demo文件下载,包含zookeeper安装文件,dubbo的监控war已经dubbo的源码

    dubbo+zookeeper+redis

    包含dubbo-monitor-simple-2.5.3-assembly.tar.gz,dubbo-admin-2.5.3.war,redis-3.0.1-win64.7z(解压版,安装版的本来准备打包一起放上,但是超过了上传限制,只能分两次上传),zookeeper-3.3.6.tar.gz,以上是...

    Dubbo zookeeper注册中心文档

    ### Dubbo与Zookeeper集成详解 #### 一、概述 在微服务架构中,服务注册与发现是非常重要的组件之一。Dubbo作为一个广泛使用的高性能、轻量级的微服务框架,通常选择Zookeeper作为其服务注册中心。Zookeeper不仅...

Global site tag (gtag.js) - Google Analytics