一、背景 
随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行。 
当越来越的的接口与实现类的增加后,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. JS互相调用

    JS互相调用 例1: <html> <head> <meta charset="UTF-8"> <script type="te ...

  2. 截取url中的某个字符串后面的值

    获取到当前网址 var url = window.location.href; http://localhost:8080/exam_questions?type=3 //获取url中的参数 func ...

  3. 使用VS2015制作安装包( 含相关的下载链接)

    补充: 在看下面的教程过程中,如果在下面的步聚1中没有 " Visual Studio Installer", 则需要通过下面的链接进行安装 Visual Studio Insta ...

  4. Centos 能ping通域名和公网ip但是网站不能够打开,服务器拒绝了请求。打开80端口解决。

    博客搬迁,给你带来的不便,敬请谅解! http://www.suanliutudousi.com/2017/10/29/centos-%E8%83%BDping%E9%80%9A%E5%9F%9F%E ...

  5. Unicode - 16 位统一超级字符集

    描述 (DESCRIPTION) 国际标准 ISO 10646 定义了 通用字符集 (Universal Character Set, UCS). UCS 包含所有别的字符集标准里的字符,并且保证了 ...

  6. win10无法设置移动热点的一种解决办法

    我的笔记本网卡为:Intel(R) Centrino(R) Wireless-N 2230 最近发现win10自带的移动热点无法启动了,一直显示无法设置热点 参考网上的教程,例如http://jing ...

  7. MySQL高可用配置(主从复制)

    主从复制包含两个步骤: 在 master 主服务器(组)上的设置,以及在 slave 从属服务器(组)上的设置. 环境: MASTER: 192.168.155.101SLAVE: 192.168.1 ...

  8. Aria2 Centos8 安装配置

    使用chkconfig 或者 chkconfig –list就可以看出当前系统已经设置的各个服务在各个运行级别下的开闭状态.如果我们想设置某个服务自启动或者关闭的话,那么只需要按照下面的格式使用即可 ...

  9. leetcood学习笔记-160*-相交链表

    题目描述: 方法一: class Solution(object): def getIntersectionNode(self, headA, headB): """ : ...

  10. Vue.js和Webpack

    Vue.js Vue简单介绍 是一个轻量级的渐进式框架,一个前端项目可以使用使用Vue.js的一两个特性也可以整个项目都用Vue.js,很方便实现项目的增量开发 Vue.js的使用:() 在html页 ...