2019独角兽企业重金招聘Python工程师标准>>>

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

一:单机模式安装zookeeper

1,下载zookeeper注册中心,下载地址:http://www.apache.org/dyn/closer.cgi/zookeeper/ 下载后解压即可,进入E:\zookeeper-3.3.6\zookeeper-3.3.6\bin,

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

zkServer.sh【Linux】或zkServer.cmd【Windows】

2,在你执行启动脚本之前,还有几个基本的配置项需要配置一下,Zookeeper的配置文件在 conf 目录下,这个目录下有 zoo_sample.cfg 和 log4j.properties,你需要做的就是将zoo_sample.cfg 改名为 zoo.cfg,因为 Zookeeper在启动时会找这个文件作为默认配置文件。下面详细介绍一下,这个配置文件中各个配置项的意义。

•tickTime:这个时间是作为Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。

•dataDir:顾名思义就是 Zookeeper保存数据的目录,默认情况下,Zookeeper 将写数据的日志文件也保存在这个目录里。

•dataLogDir:顾名思义就是Zookeeper 保存日志文件的目录

•clientPort:这个端口就是客户端连接Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求

配置好后,zookeeper会监听本机的2181端口。

当这些配置项配置好后,你现在就可以启动 Zookeeper 了,启动后要检查 Zookeeper 是否已经在服务,可以通过 netstat – ano 命令查看是否有你配置的 clientPort 端口号在监听服务。

二:服务提供者

定义服务接口:(该接口需单独打包,在服务提供方和消费方共享)

[java] view plain copy

print?

  1. package com.unj.dubbotest.provider;
  2. import java.util.List;
  3. public interface DemoService {
  4. String sayHello(String name);
  5. public List getUsers();
  6. }

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

[java] view plain copy

print?

  1. package com.unj.dubbotest.provider.impl;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import com.unj.dubbotest.provider.DemoService;
  5. public class DemoServiceImpl implements DemoService {
  6. public String sayHello(String name) {
  7. return "Hello " + name;
  8. }
  9. public List getUsers() {
  10. List list = new ArrayList();
  11. User u1 = new User();
  12. u1.setName("hejingyuan");
  13. u1.setAge(20);
  14. u1.setSex("f");
  15. User u2 = new User();
  16. u2.setName("xvshu");
  17. u2.setAge(21);
  18. u2.setSex("m");
  19. list.add(u1);
  20. list.add(u2);
  21. return list;
  22. }
  23. }

用Spring配置声明暴露服务:

[html] view plain copy

print?

  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.unj.dubbotest.provider.impl.DemoServiceImpl" />
  11. <!-- 提供方应用信息,用于计算依赖关系 -->
  12. <dubbo:application name="xs_provider" />
  13. <!-- 使用multicast广播注册中心暴露服务地址 -->
  14. <!--<dubbo:registry address="multicast://224.5.6.7:1234" /> -->
  15. <!-- 使用zookeeper注册中心暴露服务地址 --即zookeeper的所在服务器ip地址和端口号 -->
  16. <dubbo:registry address="zookeeper://192.168.24.213:2181" />
  17. <!-- 用dubbo协议在20880端口暴露服务 -->
  18. <dubbo:protocol name="dubbo" port="20880" />
  19. <!-- 声明需要暴露的服务接口 -->
  20. <dubbo:service interface="com.unj.dubbotest.provider.DemoService"
  21. ref="demoService" />
  22. </beans>

加载Spring配置,启动服务(或者将项目建为web项目,然后在web.xml中配置好spring的启动,然后扔到tomcat中即可提供服务):

[java] view plain copy

print?

  1. package com.unj.dubbotest.provider.impl;
  2. import org.springframework.context.support.ClassPathXmlApplicationContext;
  3. public class Provider {
  4. public static void main(String[] args) throws Exception {
  5. ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(
  6. new String[] { "applicationContext.xml" });
  7. context.start();
  8. System.in.read(); // 为保证服务一直开着,利用输入流的阻塞来模拟
  9. }
  10. }

三:服务消费者

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

[html] view plain copy

print?

  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="hjy_consumer" />
  11. <!-- 使用zookeeper注册中心暴露服务地址 -->
  12. <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
  13. <dubbo:registry address="zookeeper://192.168.24.213:2181" />
  14. <!-- 生成远程服务代理,可以像使用本地bean一样使用demoService -->
  15. <dubbo:reference id="demoService"
  16. interface="com.unj.dubbotest.provider.DemoService" />
  17. </beans>

调用服务测试:

[java] view plain copy

print?

  1. package com.alibaba.dubbo.demo.pp;
  2. import java.util.List;
  3. import org.springframework.context.support.ClassPathXmlApplicationContext;
  4. import com.unj.dubbotest.provider.DemoService;
  5. public class Consumer {
  6. public static void main(String[] args) throws Exception {
  7. ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(
  8. new String[] { "applicationContext.xml" });
  9. context.start();
  10. DemoService demoService = (DemoService) context.getBean("demoService");
  11. String hello = demoService.sayHello("hejingyuan");
  12. System.out.println(hello);
  13. List list = demoService.getUsers();
  14. if (list != null && list.size() > 0) {
  15. for (int i = 0; i < list.size(); i++) {
  16. System.out.println(list.get(i));
  17. }
  18. }
  19. System.in.read();
  20. }
  21. }

测试结果:

附:Dubbo的管理页面

需要下载:dubbo-admin-2.5.3的war包

下载地址:http://download.csdn.net/detail/u013286716/7041185

操作如下:

1,替换掉tomcat/webapps下自带的ROOT文件夹内容(即替换tomcat的启动主页),将下载的war包解压到webapps/ROOT中,直接替换即可

注意:jdk不要使用1.8,本次实验使用的为1.6

2,启动tomcat,访问ip:8080即可或者如果是本地的话使用localhost:8080

输入用户名密码,在E:\apache-tomcat-7.0.6-dubbo\webapps\ROOT\WEB-INF下的dubbo.properties文件中即可查看到,如:

3,访问 http://192.168.24.213:38080/

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

项目模块依赖

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

2.    项目依赖介绍

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

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

3.  项目功能部分截图:

zookeeper、dubbo服务启动

dubbo管控台

REST服务平台

转载于:https://my.oschina.net/u/2603356/blog/713571

分布式云+dubbo+zookeeper+Springmvc整合相关推荐

  1. 搭建分布式环境:Dubbo+Zookeeper

    QUESTION:搭建分布式环境:Dubbo+Zookeeper? ANSWER: 一:官网下载Zookeeper 点击官网:Zookeeper,进行下载. 下载完成,解压缩到文件. 二:配置启动Zo ...

  2. 精华【分布式、微服务、云架构dubbo+zookeeper+springmvc+mybatis+shiro+redis】分布式大型互联网企业架构!...

    2019独角兽企业重金招聘Python工程师标准>>> 框架简介--主要定位于互联网企业架构,已内置企业信息化系统的基础功能和高效的代码生成工具,包括:系统权限组件.数据权限组件.数 ...

  3. 精华【分布式微服务云架构dubbo+zookeeper+springmvc+mybatis+shiro+redis】分布式大型互联网企业架构!

    摘要: 开发工具 1.Eclipse IDE:采用Maven项目管理,模块化. 2.代码生成:通过界面方式简单配置,自动生成相应代码,目前包括三种生成方式(增删改查):单表.一对多.树结构.生成后的代 ...

  4. 分布式系统设计原理与方案Dubbo+Zookeeper+Spring整合

    2019独角兽企业重金招聘Python工程师标准>>> 一直在思考分布式系统设计的问题,业务对象原封不动的情况下部署在客户端和服务器端,可以根据配置文件选择是连接服务器还是连接本地的 ...

  5. Spring Cloud企业微服务分布式云架构技术点整合

    spring cloud本身提供的组件就很多,但我们需要按照企业的业务模式来定制企业所需要的通用架构... 下面我针对于spring cloud微服务分布式云架构做了以下技术总结,希望可以帮助到大家: ...

  6. (二)微服务分布式云架构 - spring cloud整合企业架构的技术点

    spring cloud本身提供的组件就很多,但我们需要按照企业的业务模式来定制企业所需要的通用架构,那我们现在需要考虑使用哪些技术呢? 下面我针对于spring cloud微服务分布式云架构做了以下 ...

  7. 【JEECG Dubbo专题】Dubbo+Zookeeper+Spring整合应用篇-Dubbo基于Zookeeper实现分布式服务(二)

    Dubbo与Zookeeper.Spring整合使用 Dubbo采用全Spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spri ...

  8. 分布式服务Dubbo+Zookeeper安全认证

    2019独角兽企业重金招聘Python工程师标准>>> 前言 由于之前的服务都是在内网,Zookeeper集群配置都是走的内网IP,外网不开放相关端口.最近由于业务升级,购置了阿里云 ...

  9. SpringBoot整合Dubbo+Zookeeper进行分布式搭建系统

    QUESTIONl:SpringBoot整合Dubbo+Zookeeper进行分布式搭建系统? ANSWER: 一:创建项目模块 1.1.创建一个Empty Project 名称:Dubbo 1.2. ...

最新文章

  1. R语言使用pwr包的pwr.r.test函数对相关信息分析(Correlations)进行效用分析(power analysis)的语法
  2. 重构-改善既有代码的设计:编写代码22宗罪(三)
  3. Aop事务小结(事务管理器和自身构建)
  4. bagging and boosting
  5. js使用hover事件做一个“个人中心”的浮动层
  6. 【Networking】容器网络大观 SDN 资料汇总
  7. 云服务器ECS登陆注意点
  8. 计算机文化基础在线作业答案,地大《计算机文化基础》在线作业一答案.doc
  9. avl树 php,PHP实现平衡二叉树(AVL树)
  10. 使用Mybatis实例
  11. linux安装unity桌面环境,Ubuntu 14.04 server安装桌面环境
  12. 从零开始研发GPS接收机连载——4、GPS模拟器数据采集验证
  13. unity3d 资源打包加密 整理
  14. 高通平台开发系列讲解(USB篇)MBIM QXDM 日志解析
  15. 100以内的奇数求和
  16. Spark 学习【一】
  17. Python项目分析:预测双色球福利彩票中奖号码(随便玩玩,不要当真)
  18. 2022-2027年中国发动机行业市场调研及未来发展趋势预测报告
  19. 调用百度Api实现音频转写
  20. 简洁易懂的配置Go开发环境MacOS

热门文章

  1. 单选按钮设置为被选中状态_为什么要设置错误的按钮状态
  2. 面了三次字节,他的一些感悟
  3. 面试官问:来实现一个Promise
  4. 【更名通知】将以个人名义继续更新维护
  5. goaccess_nginx日志分析工具
  6. Internet概念与TCP/ IP分层模型
  7. 监控主机安装需要材料
  8. [导入]ASP.NET MVC的WebSite模式(with mvc membership)
  9. 在类中用class时数据是共有还是私有_jvm学习笔记之class文件的加载、初始化
  10. Javascript基础学习20问(二)