为什么要用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. # The number of milliseconds of each tick
  2. tickTime=2000
  3. # The number of ticks that the initial
  4. # synchronization phase can take
  5. initLimit=10
  6. # The number of ticks that can pass between
  7. # sending a request and getting an acknowledgement
  8. syncLimit=5
  9. # the directory where the snapshot is stored.
  10. dataDir=/tmp/zookeeper
  11. # the port at which the clients will connect
  12. 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. dubbo.registry.address=zookeeper://127.0.0.1:2181
  2. dubbo.admin.root.password=root
  3. dubbo.admin.guest.password=guest

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

修改完成后需要一个tomcat   打开tomcat     \webapps\ROOT 目录 ,此目录放置的是tomcat的首页,删除所有的文件,将解压后修改好的所有的dubbo-admin 里的文件复制到 \webapps\ROOT中,

此时我们已经配置好了。现在可以启动tomcat了 (主意:在启动tomcat之前要先启动zookeeper ,启动zookeeper前面有介绍)。 启动tomcat之后 在浏览器输入 http://localhost:8080  (我的是8083) 进入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. package com.cl.user.serviceImpl;
  2.  
  3. import org.springframework.stereotype.Service;
  4.  
  5. import com.cl.user.servicei.UserService;
  6.  
  7. @Service("userService")
  8. public class UserServiceImpl implements UserService{
  9.  
  10. @Override
  11. public String sayHello() {
  12.  
  13. System.out.println("hello world----------------------------");
  14.  
  15. return "hello world";
  16.  
  17. }
  18. }
 
有了 实现类 还需要接口  也就是项目test-public-interface 
 
 
这个项目很简单 只需要 接口 就行了
  1. package com.cl.user.servicei;
  2.  
  3. public interface UserService {
  4. public String sayHello();
  5.  
  6. }

当然 项目 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服务的配置

  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
  1. @Controller
  2. public class UserController {
  3.  
  4. @Resource(name="userService")
  5. private UserService userService;
  6.  
  7. @RequestMapping("/hello/test/world")
  8. public void sayHello(){
  9. System.out.println(userService.sayHello()+"**************************");
  10. }
  11. }

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

  1. <mvc:annotation-driven/>
  2. <mvc:default-servlet-handler/>
  3. <context:component-scan base-package="com" />
  4.  
  5. <!-- 对静态资源文件的访问 restful-->
  6. <mvc:resources mapping="/js/**" location="/js/" />
  7. <mvc:resources mapping="/lib/**" location="/lib/" />
  8. <mvc:resources mapping="/plugins/**" location="/plugins/" />
  9. <mvc:resources mapping="/uploadFiles/**" location="/uploadFiles/" />
  10. <mvc:resources mapping="/WEB-INF/html/**" location="/WEB-INF/html/" />
  11.  
  12. <!-- 配置SpringMVC的视图解析器 -->
  13. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  14. <property name="prefix" value="/WEB-INF/html"/>
  15. <property name="suffix" value=".jsp"/>
  16. </bean>
  17.  
  18. <!-- 上传拦截,如最大上传值及最小上传值 -->
  19. <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver" >
  20. <property name="maxUploadSize">
  21. <value>104857600</value>
  22. </property>
  23. <property name="maxInMemorySize">
  24. <value>4096</value>
  25. </property>
  26. <property name="defaultEncoding">
  27. <value>utf-8</value>
  28. </property>
  29. </bean>

ApplicationContext-dubbo.xml

  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 http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
  5. http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
  6.  
  7. <!-- 消费方应用名,用于计算依赖关系,不是匹配条件,不要与提供方一样 -->
  8. <dubbo:application name="hehe_consumer" />
  9.  
  10. <!-- 使用zookeeper注册中心暴露服务地址 -->
  11.  
  12. <dubbo:registry address="zookeeper://127.0.0.1:2181" />
  13.  
  14. <!-- 组播注册 -->
  15. <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
  16.  
  17. <!-- 生成远程服务代理,可以像使用本地bean一样使用userService -->
  18. <dubbo:reference id="userService" interface="com.cl.user.servicei.UserService" />
  19. </beans>

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

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

 
最后 ,在开发的时候为了方便,我们可以使用组播注册!
  1. <!-- 组播注册 -->
  2. <!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
 源码:
 https://github.com/KellyLChen/Dubbo.git
 
 
 
作者原创转载请说明:http://www.cnblogs.com/c9999/p/6019307.html
 

域名购买.com 后缀好域名 

https://mi.aliyun.com/shop/38040

 
 
 
 
 
 
 
 
 

maven+springmvc+dubbo+zookeeper的更多相关文章

  1. 关于Maven+Springmvc+Dubbo+Zookeeper整合

    为什么要用dubbo?   还是让官方来解释吧: http://dubbo.io/User+Guide-zh.htm   http://dubbo.io/   一般 nginx+tomcat  | - ...

  2. Dubbo与Zookeeper、Spring整合使用 maven+springmvc+dubbo+zookeeper

    为什么要用dubbo?   还是让官方来解释吧: http://dubbo.io/User+Guide-zh.htm   http://dubbo.io/   一般 nginx+tomcat  | - ...

  3. 170328、Maven+SpringMVC+Dubbo 简单的入门demo配置

    之前一直听说dubbo,是一个很厉害的分布式服务框架,而且巴巴将其开源,这对于咱们广大程序猿来说,真是一个好消息.最近有时间了,打算做一个demo把dubbo在本地跑起来先. 先copy一段dubbo ...

  4. Maven+SpringMVC+Dubbo 简单的入门demo配置

    转载自:https://cloud.tencent.com/developer/article/1010636 之前一直听说dubbo,是一个很厉害的分布式服务框架,而且巴巴将其开源,这对于咱们广大程 ...

  5. MAC环境下idea:maven+Spring+Dubbo+Zookeeper简单工程搭建

    : 一:安装软件:tomcatZookeeperDubbo+admin 二:工程: 总工程  API    Pom.xml:不用引用任何东西  Provider    Pom.xml:要denpend ...

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

    平台简介 Jeesz是一个分布式的框架,提供项目模块化.服务化.热插拔的思想,高度封装安全性的Java EE快速开发平台. Jeesz本身集成Dubbo服务管控.Zookeeper注册中心.Redis ...

  7. 分布式架构真正适用于大型互联网项目的架构! dubbo+zookeeper+springmvc+mybatis+shiro+redis

     分类: 分布式技术(3)    目录(?)[+]   平台简介 Jeesz是一个分布式的框架,提供项目模块化.服务化.热插拔的思想,高度封装安全性的Java EE快速开发平台. Jeesz本身集成D ...

  8. 搭建SpringBoot+dubbo+zookeeper+maven框架(二)

    上一篇文章是关于搭建SpringBoot+dubbo+zookeeper+maven框架的,但是里面的功能还不够完善,今天就日志管理方面做一些改善. 下了demo的网友可能会发现项目在启动时会有警告: ...

  9. 搭建SpringBoot+dubbo+zookeeper+maven框架(一)

    这几天项目还没来,所以就自己试着参考网上的一些资料,搭建了一个SpringBoot+dubbo+zookeeper+maven框架,网上参考的很多资料照着他们一步一步搭建,最后很多都运行不通,很是郁闷 ...

随机推荐

  1. python 数据类型---列表使用之三

    1. 判断列表中是否存在一个元素: "in" 的使用 list = ['Frank', 99, 'is',78, 7,3,4,'smart'] print(99 in list) ...

  2. C语言计算字符串子串出现的次数

    #include<stdio.h>#include<string.h>int substring(char *str,char *str1);//函数原型int main(vo ...

  3. 解决phalcon model在插入或更新时会自动验证非空字段

    在使用phalcon的insert和update功能时,因为数据库所有的字段设置的都是NOT NULL,而phalcon的model在插入或更新之前会自动判断字段是否需要必填,因此导致有空字段时无法存 ...

  4. 商业智能BI推动制造业智能化转型

    制造业是我国国民经济的支柱产业,是我国经济增长的主导部门和经济转型的基础,如今我国制造业面临技术工艺不精.缺乏市场意识.商贸流通环节多.物流成本大.仓储效率低下等问题,正处在转型的特殊时期. 内忧: ...

  5. CentOS7 查看IP、Gateway、DNS、Hostname

    1.查看IP# ip addr 2.查看路由# ip route 3.查看DNS# cat /etc/resolv.conf 4.查看主机名# hostname

  6. Scala 变长参数

    如果Scala定义变长参数 def sum(i Int*), 那么调用sum时,可以直接输入sum(1,2,3,4,5) 但是不可以sum(1 to 5) 必须要将1 to 5 强制为seq sum( ...

  7. vs2010中如何设置Visual Assist方便地使用现成的代码编辑器风格

    风格setting可以在下面网站上获取: http://studiostyl.es/ 在VS2010+VA直接使用会有2个显著的问题: 1,有些符号颜色太深,与黑色背景几乎融为一体: 2,光标落入大小 ...

  8. MongoDB学习笔记一—简介

    MongoDB简介 MongoDB在功能和复杂性之间取得了很好的平衡,并且大大简化了原先十分复杂的任务,它具备支撑今天主流web应用的关键功能:索引.复制.分片.丰富的查询语法,特别灵活的数据模型.与 ...

  9. ORACLE lag()与lead() 函数

    一.简介 lag与lead函数是跟偏移量相关的两个分析函数,通过这两个函数可以在一次查询中取出同一字段的前N行的数据(lag)和后N行的数据(lead)作为独立的列,从而更方便地进行进行数据过滤.这种 ...

  10. Oracle学习笔记六 SQL常用函数

    函数的分类 Oracle 提供一系列用于执行特定操作的函数 SQL 函数带有一个或多个参数并返回一个值 以下是SQL函数的分类: