Dubbo 简单的入门【Maven+SpringMVC+Dubbo 】

由于没有下载

Maven+SpringMVC+Dubbo 简单的入门demo配置 源码

三分,所以只好按 哎_小羊_168的文档

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

依葫芦画瓢的自己写了一个,考虑到和有相同境遇的人不会少,所以和大家分享一下。

言归正传:

一、软件环境 
1、zookeeper 
自己百度下载,这里使用的版本是 zookeeper-3.4.9 
2、springMVC (maven方式引入) 
3、dubbo (maven方式引入)

4、java


二、项目搭建 
这里我搭建了三个项目,分别为dubbo-controller,dubbo-service ,dubbo-serviceImpl
dubbo-service:主要是接口定义,供controller调用,以及serviceImpl层去实现该接口,分离这一层的好处就是前段项目调用接口时候,直接调用dubbo-service的接口即可,不需要关注后端如何实现;而serviceImpl层来具体实现该接口,进行业务逻辑处理,不需要关注 controller层如何调用。 
dubbo-controller:主要controller层控制跳转等。 
dubbo-serviceImpl:主要是service实现,结合数据层实现后端业务逻辑处理。

项目搭建完成之后,的结构图如下: 


三、项目配置 
1、dubbo-service 
新建TestService接口类

package com.link.dubbo.service;


/** 
 * @ClassName: TestService 
 * @Description: 测试发消息 
 * @author:  
 * @date 2017年10月14日 上午11:51:15 
 *  
 */
public interface TestService {
/**
     * 测试发消息
     * @param name
     * @return
     */
    public String sayHello(String name);


}

pom.xml配置

<?xml version="1.0"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <parent>
    <groupId>com.link.dubbo</groupId>
    <artifactId>dubbo-test</artifactId>
    <version>0.0.1-SNAPSHOT</version>
  </parent>
  <groupId>com.link.dubbo</groupId>
  <artifactId>dubbo-service</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <name>dubbo-service</name>
  <url>http://maven.apache.org</url>
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    
  </dependencies>
</project>

注意: 这个项目最终打包成jar文件,直接maven引入到另外两个项目中

2、dubbo-controller 
新建MyController类

package com.link.dubbo.controller;


import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;


import com.link.dubbo.service.TestService;


/** 
 * @ClassName: MyController 
 * @Description:  
 * @author:  
 * @date 2017年10月15日 下午12:08:15 
 *  
*/
@Controller
@RequestMapping(value = "/mc")
public class MyController {
@Autowired
    private TestService testService;


    @RequestMapping(value = "/test")
    @ResponseBody
    public String testSay(@RequestParam(value = "name",defaultValue = "") String name){
        StringBuffer sb = new StringBuffer();
        sb.append("Dubbo: ").append(testService.sayHello(name));
        return sb.toString();
    }


}

新建dubbo-config.xml

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


    <!-- 提供方应用信息,用于计算依赖关系 -->
    <dubbo:application name="test_consumer" />


    <!-- 使用zookeeper注册中心暴露服务地址 -->
    <dubbo:registry address="zookeeper://192.168.8.177:2181" />


    <!-- 声明需要暴露的服务接口 -->
    <dubbo:reference interface="com.link.dubbo.service.TestService" id="testService" check="false" />


</beans>

注意:这里作为消费者名称为test_consumer,注释很详细,就不一一介绍了,这个项目最终打包成dubbo-controller.war放在tomcat或其他容器中运行。

pom.xml配置

<?xml version="1.0"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <parent>
    <groupId>com.link.dubbo</groupId>
    <artifactId>dubbo-test</artifactId>
    <version>0.0.1-SNAPSHOT</version>
  </parent>
  <groupId>com.link.dubbo</groupId>
  <artifactId>dubbo-controller</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>war</packaging>
  <name>dubbo-controller Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    <dependency>
    <groupId>com.link.dubbo</groupId>
    <artifactId>dubbo-service</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    </dependency>
    <!-- Spring 相关 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>3.2.16.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>3.2.16.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>3.2.16.RELEASE</version>
</dependency>
<!-- JSP、servlet 相关 -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
</dependency>


    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>dubbo</artifactId>
        <version>2.5.3</version>
        <exclusions>
            <exclusion>
                <artifactId>spring</artifactId>
                <groupId>org.springframework</groupId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.apache.zookeeper</groupId>
        <artifactId>zookeeper</artifactId>
        <version>3.3.6</version>
        <exclusions>
            <exclusion>
                <groupId>log4j</groupId>
                <artifactId>log4j</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.16</version>
    </dependency>
    <dependency>
      <groupId>com.github.sgroschupf</groupId>
      <artifactId>zkclient</artifactId>
      <version>0.1</version>
    </dependency>
  </dependencies>
  <build>
    <finalName>dubbo-controller</finalName>
  </build>
</project>

3、dubbo-serviceImpl 
新建TestServiceImpl类

package com.link.dubbo.serviceImpl;


import com.link.dubbo.service.TestService;


/** 
 * @ClassName: TestServiceImpl 
 * @Description: TODO(这里用一句话描述这个类的作用) 
 * @author:  
 * @date 2017年10月15日 上午11:57:20 
 *  
*/
public class TestServiceImpl implements TestService {


/* (非 Javadoc) 
* <p>Title: sayHello</p> 
* <p>Description: </p> 
* @param name
* @return 
* @see com.link.dubbo.service.TestService#sayHello(java.lang.String) 
*/
@Override
public String sayHello(String name) {
return name + " TestServiceImpl say hello word TestServiceImpl!";
}


}

新建applicationContext.xml

<?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:p="http://www.springframework.org/schema/p"
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
    http://code.alibabatech.com/schema/dubbo
    http://code.alibabatech.com/schema/dubbo/dubbo.xsd">


    <!-- 提供方应用信息,用于计算依赖关系 -->
    <dubbo:application name="test_provider" />


    <!-- 使用zookeeper注册中心暴露服务地址 -->
    <dubbo:registry address="zookeeper://192.168.8.177:2181" />


    <!-- 用dubbo协议在20880端口暴露服务 -->
    <dubbo:protocol name="dubbo" port="20880" />


    <!-- 声明需要暴露的服务接口 -->
    <dubbo:service interface="com.link.dubbo.service.TestService" ref="testService" />


    <!-- 具体的实现bean -->
    <bean id="testService" class="com.link.dubbo.serviceImpl.TestServiceImpl" />
</beans>

注意:这里作为服务提供者名称为test_provider,这个项目最终打包成dubbo-serviceImpl.war放在tomcat或其他容器中运行。

pom.xml配置

<?xml version="1.0"?>
<project
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.link.dubbo</groupId>
<artifactId>dubbo-test</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<groupId>com.link.dubbo</groupId>
<artifactId>dubbo-serviceImpl</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>dubbo-serviceImpl Maven Webapp</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.link.dubbo</groupId>
<artifactId>dubbo-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.5.3</version>
<exclusions>
<exclusion>
<artifactId>spring</artifactId>
<groupId>org.springframework</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.6</version>
<exclusions>
<exclusion>
<artifactId>log4j</artifactId>
<groupId>log4j</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.6.9</version>
</dependency>
<dependency>
<groupId>commons-pool</groupId>
<artifactId>commons-pool</artifactId>
<version>1.5.3</version>
</dependency>
<dependency>
<groupId>commons-collections</groupId>
<artifactId>commons-collections</artifactId>
<version>3.2</version>
</dependency>
<!-- Spring 相关 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>3.2.16.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>3.2.16.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>3.2.16.RELEASE</version>
</dependency>
<!-- JSP、servlet 相关 -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
</dependency>
<dependency>
<groupId>commons-httpclient</groupId>
<artifactId>commons-httpclient</artifactId>
<version>3.1</version>
</dependency>
</dependencies>
<build>
<finalName>dubbo-serviceImpl</finalName>
</build>
</project>

maven编译下三个项目,将dubbo-controller和dubbo-serviceImpl放到tomcat容器中,启动tomcat容器! 出错啦! 为啥容器不起来!那是因为我们还少了主要的一步,那就是配置启动zookeeper,不然dubbo去zookeeper注册中心暴露服务地址不成功啦!

四、配置启动zookeeper 

在 CentOS-6.6上安装 zookeeper-3.4.9 服务

4. 1、创建/usr/local/services/zookeeper 文件夹:

    mkdir-p /usr/local/services/zookeeper

 

4.2、进入到/usr/local/services/zookeeper 目录中:

    cd/usr/local/services/zookeeper

 

4.3、下载zookeeper-3.4.9.tar.gz:

   wget https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.4.9/zookeeper-3.4.9.tar.gz

 

4.4、解压缩zookeeper-3.4.9.tar.gz:

    tar-zxvf zookeeper-3.4.9.tar.gz

 

4.5、进入到/usr/local/services/zookeeper/zookeeper-3.4.9/conf 目录中:

    cdzookeeper-3.4.9/conf/

 

4.6、复制 zoo_sample.cfg文件的并命名为为 zoo.cfg:

    cpzoo_sample.cfg zoo.cfg

 

4.7、用 vim 打开 zoo.cfg文件并修改其内容为如下:

    # Thenumber of milliseconds of each tick

 

   # zookeeper 定义的基准时间间隔,单位:毫秒

   tickTime=2000

 

    # Thenumber of ticks that the initial 

    #synchronization phase can take

   initLimit=10

    # Thenumber of ticks that can pass between 

    #sending a request and getting an acknowledgement

   syncLimit=5

    # thedirectory where the snapshot is stored.

    # donot use /tmp for storage, /tmp here is just 

    #example sakes.

    #dataDir=/tmp/zookeeper

 

   # 数据文件夹

   dataDir=/usr/local/services/zookeeper/zookeeper-3.4.9/data

 

   # 日志文件夹

   dataLogDir=/usr/local/services/zookeeper/zookeeper-3.4.9/logs

 

    # theport at which the clients will connect

   # 客户端访问 zookeeper 的端口号

   clientPort=2181

 

    # themaximum number of client connections.

    #increase this if you need to handle more clients

   #maxClientCnxns=60

    #

    # Besure to read the maintenance section of the 

    #administrator guide before turning on autopurge.

    #

   # http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance

    #

    # Thenumber of snapshots to retain in dataDir

   #autopurge.snapRetainCount=3

    #Purge task interval in hours

    # Setto "0" to disable auto purge feature

   #autopurge.purgeInterval=1

 

4.8、保存并关闭 zoo.cfg 文件:

    

4.9、进入到/usr/local/services/zookeeper/zookeeper-3.4.9/bin 目录中:

    cd../bin/

 

4.10、用 vim 打开 /etc/目录下的配置文件 profile:

    vim/etc/profile

   并在其尾部追加如下内容:

 

    # idea- zookeeper-3.4.9 config start - 2016-09-08

 

    exportZOOKEEPER_HOME=/usr/local/services/zookeeper/zookeeper-3.4.9/

    exportPATH=$ZOOKEEPER_HOME/bin:$PATH

    exportPATH

 

    # idea- zookeeper-3.4.9 config start - 2016-09-08

 

4.11、使 /etc/ 目录下的profile 文件即可生效:

    source/etc/profile

 

4.12、启动 zookeeper 服务:

   zkServer.sh start

   如打印如下信息则表明启动成功:

   ZooKeeper JMX enabled by default

    Usingconfig: /usr/local/services/zookeeper/zookeeper-3.4.9/bin/../conf/zoo.cfg

   Starting zookeeper ... STARTED

 

4.13、查询 zookeeper 状态:

   zkServer.sh status

 

4.14、关闭 zookeeper 服务:

   zkServer.sh stop

   如打印如下信息则表明成功关闭:

   ZooKeeper JMX enabled by default

    Usingconfig: /usr/local/services/zookeeper/zookeeper-3.4.9/bin/../conf/zoo.cfg

   Stopping zookeeper ... STOPPED

 

4.15、重启 zookeeper 服务:

   zkServer.sh restart

   如打印如下信息则表明重启成功:

   ZooKeeper JMX enabled by default

    Usingconfig: /usr/local/services/zookeeper/zookeeper-3.4.9/bin/../conf/zoo.cfg

   ZooKeeper JMX enabled by default

    Usingconfig: /usr/local/services/zookeeper/zookeeper-3.4.9/bin/../conf/zoo.cfg

   Stopping zookeeper ... STOPPED

   ZooKeeper JMX enabled by default

    Usingconfig: /usr/local/services/zookeeper/zookeeper-3.4.9/bin/../conf/zoo.cfg

   Starting zookeeper ... STARTED

 再次启动tomcat容器,访问下http://127.0.0.1:8888/dubbo-controller/mc/test?name=666,看下返回结果是不是正确啦!


本次demo就结束了。

五、dubbo Admin

5.1、下载dubbo

http://dubbo.io

5.2、编译dubbo Admin

5.3、将编译好的war文件解压后,将文件夹中的全部文件复制到Tomcat文件夹webapps中的ROOT内

一定要放到ROOT内,否则dubboAdmin中有写页面链接会报异常

5.4、运行TOMCAT


提供者


消费者


执行 http://127.0.0.1:8888/dubbo-controller/mc/test?name=666后,可以看到消费次数


最后参考资料: 
dubbo用户指南 
dubbo开发者指南 
dubbo源码

demo项目源码已上传到download 
demo项目源码地址:Dubbo 简单的入门【Maven+SpringMVC+Dubbo 】源码

对不起朋友们,不能设置0分,以前是可以的。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值