溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

duboo的使用分析

發(fā)布時(shí)間:2021-11-10 18:49:22 來源:億速云 閱讀:170 作者:柒染 欄目:大數(shù)據(jù)

今天就跟大家聊聊有關(guān)duboo的使用分析,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

一、背景

隨著互聯(lián)網(wǎng)的發(fā)展,網(wǎng)站應(yīng)用的規(guī)模不斷擴(kuò)大,常規(guī)的垂直應(yīng)用架構(gòu)已無法應(yīng)對(duì),分布式服務(wù)架構(gòu)以及流動(dòng)計(jì)算架構(gòu)勢在必行。

當(dāng)越來越的的接口與實(shí)現(xiàn)類的增加后,duboo的xml配置會(huì)越來越多,為了防止幾百幾千行的代碼,減少開發(fā)人員配置xml的工作量,使用duboo的注解模式,減少配置多出問題多的可能性!

二、Dubbo使用案例

Duboo注解

接口類項(xiàng)目:DubboServiceInterface

duboo的使用分析

僅僅是一個(gè)接口類項(xiàng)目!接口是普通接口!

duboo的使用分析

注意:將接口類項(xiàng)目打包成jar分別放入服務(wù)端項(xiàng)目跟客戶端項(xiàng)目!

服務(wù)端項(xiàng)目:DubboServiceProvider

duboo的使用分析

實(shí)現(xiàn)類fooserviceImpl.java

duboo的使用分析

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 配置掃描內(nèi)容

duboo的使用分析

<?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 配置

duboo的使用分析

<?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">  

<!-- 服務(wù)端- 服務(wù)提供方   -->

   <!-- 公共信息,也可以用dubbo.properties配置 -->

   <dubbo:application name="test" />

<!--    鏈接zookeeper -->

   <dubbo:registry address="zookeeper://127.0.0.1:2181/" group="test"/>

   <dubbo:consumer timeout="5000"/>

   <!-- 掃描注解包路徑,多個(gè)包用逗號(hào)分隔,不填pacakge表示掃描當(dāng)前ApplicationContext中所有的類 -->

<dubbo:annotation package="com.unj.dubbotest.serviceImp" /> 

<!-- xml配置 : 聲明需要暴露的服務(wù)接口 -->

<!--      <dubbo:service interface="com.alibaba.dubbo.demo.DemoService" ref="demoService" /> -->

    <!-- xml配置 :和本地bean一樣實(shí)現(xiàn)服務(wù)-->

<!--     <bean id="demoService" class="com.unj.dubbotest.serviceImp.FooServiceImpl" /> -->

</beans>

測試類Provider

 duboo的使用分析

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包

duboo的使用分析

客戶端項(xiàng)目:DubboServiceConsumer

duboo的使用分析

web.xml 配置掃描內(nèi)容

duboo的使用分析

applicationContext.xml文件

duboo的使用分析

<?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">  

<!-- 客戶端- 服務(wù)消費(fèi)方   -->

   <!-- 公共信息,也可以用dubbo.properties配置 -->

   <dubbo:application name="xx" />

   <dubbo:registry address="zookeeper://127.0.0.1:2181" />

   <dubbo:consumer timeout="5000"/>

 <!-- 掃描注解包路徑,多個(gè)包用逗號(hào)分隔,不填pacakge表示掃描當(dāng)前ApplicationContext中所有的類 -->

    <dubbo:annotation package="com.unj.dubbotest.action" />

</beans>

測試類:Consumer

duboo的使用分析

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"); // 獲取遠(yuǎn)程服務(wù)代理 

       String hello = demoService.sayHello("world"); // 執(zhí)行遠(yuǎn)程方法 

       System.out.println( hello ); // 顯示調(diào)用結(jié)果 

   }

}

lib下的jar包

duboo的使用分析

看完上述內(nèi)容,你們對(duì)duboo的使用分析有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI