一、背景 
随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行。 
当越来越的的接口与实现类的增加后,duboo的xml配置会越来越多,为了防止几百几千行的代码,减少开发人员配置xml的工作量,使用duboo的注解模式,减少配置多出问题多的可能性!

二、Dubbo使用案例 
Duboo注解 
接口类项目:DubboServiceInterface

仅仅是一个接口类项目!接口是普通接口!

注意:将接口类项目打包成jar分别放入服务端项目跟客户端项目! 
服务端项目:DubboServiceProvider

实现类fooserviceImpl.java

package com.alibaba.dubbo.demo.imp;

import com.alibaba.dubbo.config.annotation.Service; 
import com.alibaba.dubbo.demo.DemoService; 
@Service(version="1.0") 
public class FooServiceImpl implements DemoService { 
@Override 
public String sayHello(String name) { 
        return "Hello " + name; 
    } 

web.xml 配置扫描内容

<?xml version="1.0" encoding="UTF-8"?> 
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> 
  <display-name>DubboServiceProvider</display-name> 
<servlet> 
<servlet-name>spring</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
<load-on-startup>1</load-on-startup> 
</servlet> 
<servlet-mapping> 
<servlet-name>spring</servlet-name> 
<url-pattern>*</url-pattern> 
</servlet-mapping> 
  <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
</listener> 
    <context-param> 
<param-name>contextConfigLocation</param-name> <param-value>classpath*:applicationContext.xml</param-value> 
</context-param> 
</web-app> 
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: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.properties配置 --> 
  <dubbo:application name="test" /> 
<!--   链接zookeeper --> 
  <dubbo:registry address="zookeeper://127.0.0.1:2181/" group="test"/> 
  <dubbo:consumer timeout="5000"/> 
  <!-- 扫描注解包路径,多个包用逗号分隔,不填pacakge表示扫描当前ApplicationContext中所有的类 --> 
<dubbo:annotation package="com.unj.dubbotest.serviceImp" /> 
  
<!-- xml配置 : 声明需要暴露的服务接口 --> 
<!--      <dubbo:service interface="com.alibaba.dubbo.demo.DemoService" ref="demoService" /> --> 
   <!-- xml配置 :和本地bean一样实现服务--> 
<!--     <bean id="demoService" class="com.unj.dubbotest.serviceImp.FooServiceImpl" /> --> 
</beans> 
测试类Provider

package com.alibaba.dubbo.test;

import java.io.IOException; 
import org.junit.Before; 
import org.junit.Test; 
import org.springframework.context.support.ClassPathXmlApplicationContext; 
public class Provider { 
@Before 
public void setUp() throws Exception { 

@Test 
public void testMain() throws IOException { 
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext( 
new String[] { "applicationContext.xml" }); 
context.start(); 
System.in.read();// 按任意键退出 


lib下的jar包

客户端项目:DubboServiceConsumer

web.xml 配置扫描内容

applicationContext.xml文件

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans"  
xmlns:context="http://www.springframework.org/schema/context" 
    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.properties配置 --> 
  <dubbo:application name="xx" /> 
  <dubbo:registry address="zookeeper://127.0.0.1:2181" /> 
  <dubbo:consumer timeout="5000"/> 
<!-- 扫描注解包路径,多个包用逗号分隔,不填pacakge表示扫描当前ApplicationContext中所有的类 --> 
    <dubbo:annotation package="com.unj.dubbotest.action" /> 
</beans> 
测试类:Consumer

package com.unj.dubbotest.action; 
import java.io.IOException; 
import org.junit.Test; 
import org.springframework.context.support.ClassPathXmlApplicationContext; 
import com.alibaba.dubbo.config.annotation.Reference; 
import com.alibaba.dubbo.demo.DemoService; 
public class Consumer{ 
@Reference(version = "1.0") 
private DemoService demoService;

@Test 
public  void mainTest() throws IOException { 
ClassPathXmlApplicationContext context =new ClassPathXmlApplicationContext( 
new String[] {"applicationContext.xml"}); 
        context.start(); 
         demoService = (DemoService)context.getBean("demoService"); // 获取远程服务代理 
        String hello = demoService.sayHello("world"); // 执行远程方法 
        System.out.println( hello ); // 显示调用结果 
    } 

lib下的jar包

获取海量视频

duboo注解使用详解的更多相关文章

  1. 转:springmvc常用注解标签详解

    Spring5:@Autowired注解.@Resource注解和@Service注解 - IT·达人 - 博客园--这篇顺序渐进,讲得超级好--此人博客很不错http://www.cnblogs.c ...

  2. Java 注解用法详解——@SuppressWarnings

    转自: https://www.cnblogs.com/fsjohnhuang/p/4040785.html Java魔法堂:注解用法详解——@SuppressWarnings   一.前言 编码时我 ...

  3. @SuppressWarnings注解用法详解

    @SuppressWarnings注解用法详解 今天来谈谈@SuppressWarnings注解的作用. J2SE 提供的最后一个批注是 @SuppressWarnings.该批注的作用是给编译器一条 ...

  4. Spring 注解@Value详解

    一.spring(基础10) 注解@Value详解[1] 一 配置方式 @value需要参数,这里参数可以是两种形式: [html] view plain copy @Value("#{co ...

  5. Java注解(Annotation)详解

    转: Java注解(Annotation)详解 幻海流心 2018.05.23 15:20 字数 1775 阅读 380评论 0喜欢 1 Java注解(Annotation)详解 1.Annotati ...

  6. springmvc常用注解标签详解

    1.@Controller 在SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ...

  7. android注解使用详解(图文)

    在使用Java的SSH框架的时候,一直在感叹注解真是方便啊,关于注解的原理,大家可以参考我的另一片文章Java注解详解.最近有时间研究了android注解的使用,今天与大家分享一下. android中 ...

  8. springmvc常用注解标签详解【转】

    转载自:http://www.cnblogs.com/leskang/p/5445698.html 1.@Controller 在SpringMVC 中,控制器Controller 负责处理由Disp ...

  9. spring security 注解@EnableGlobalMethodSecurity详解

     1.Spring Security默认是禁用注解的,要想开启注解,需要在继承WebSecurityConfigurerAdapter的类上加@EnableGlobalMethodSecurity注解 ...

随机推荐

  1. Quartz CronTrigger 整配置说明

    Quartz cron 表达式的格式向下支持到秒级别的计划,而 UNIX cron 计划仅支持至分钟级.  Quartz用cron 表达式存放执行计划,引用了cron表达式的CronTrigger在计 ...

  2. fabs() abs()

    fabs() 面向实数取绝对值 abs() 返回int

  3. GetModuleHandleW 分析

    首先查询MSDN,可以清楚地看到 位于kernel32 dll 里面. 有目标就好办,找到这个dll,然后,开工,进入IDA. 跳啊 就到下面那块了. 遗憾的是...显然不是这里阿,实际上下一块调用的 ...

  4. Ubuntu安装mongo可视化工具

    一.robo 3T 是mongodb的一个非常好用的可视化管理工具,曾经名为robomongo,现在被收购后改名为robo 3T.且现在robo 3T 1.1版本能支持mongodb3.4.现在在Ub ...

  5. react 点击事件传值

    test(e){ console.log(e.target) } <button onClick={(e)=>{this.test(e)}}></button> 有时要是 ...

  6. wc - 输出文件中的字节数、单词数、行数

    SYNOPSIS 总览 wc [选项列表]... [文件名列表]... DESCRIPTION 描述 对每个文件输出行.单词.和字节统计数,如果指定了多于一个文件则还有一个行数的总计.没有指定文件或指 ...

  7. tomcat+apache+jk

    安装JDK下载地址 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html安装 rpm ...

  8. 读书笔记一、numpy基础--创建数组

    创建ndarray   (1)使用array函数 接受一切序列型的对象(包括其他数组),然后产生一个新的含有传入数据的numpy数组. import numpy as np #将一个由数值组成列表作为 ...

  9. php array remove empty values

    print_r(array_filter($linksArray)); 參考 Remove empty array elements Remove Empty Array Elements In PH ...

  10. Android Android Studio 如何导出 Jar 给 Unity 使用

    大致步骤如下: 1.创建新的 Android Studio 工程 2.为此 Android Studio 工程创建 Android Library 类库(也就是一个 Module)(后面就是用它生成 ...