日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 综合教程 >内容正文

综合教程

Dubbo直连方式

發(fā)布時(shí)間:2024/1/3 综合教程 24 生活家
生活随笔 收集整理的這篇文章主要介紹了 Dubbo直连方式 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、簡(jiǎn)介

官網(wǎng):http://dubbo.apache.org/zh-cn/

Dubbo是[1]阿里巴巴公司開源的一個(gè)高性能優(yōu)秀的服務(wù)框架,使得應(yīng)用可通過高性能的 RPC 實(shí)現(xiàn)服務(wù)的輸出和輸入功能,可以和[2]Spring框架無縫集成。

Dubbo是一款高性能、輕量級(jí)的開源Java RPC框架,它提供了三大核心能力:面向接口的遠(yuǎn)程方法調(diào)用,智能容錯(cuò)和負(fù)載均衡,以及服務(wù)自動(dòng)注冊(cè)和發(fā)現(xiàn)

二、Dubbo程序(直連式)

業(yè)務(wù)接口名即服務(wù)名稱。無論是服務(wù)提供者向服務(wù)注冊(cè)中心注冊(cè)服務(wù),還是服務(wù)消費(fèi)者從注冊(cè)中心索取服務(wù),都是通過接口名稱進(jìn)行注冊(cè)與查找的。即,提供者與消費(fèi)者都依賴于業(yè)務(wù)接口。所以,一般情況下,會(huì)將業(yè)務(wù)接口專門定義為一個(gè)工程,讓提供者與消費(fèi)者依賴

三、創(chuàng)建業(yè)務(wù)接口工程00-api

(1)創(chuàng)建業(yè)務(wù)接口工程00-api


(2)創(chuàng)建業(yè)務(wù)接口

(3) 修改pom文件

<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0"         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0</modelVersion>     <groupId>00-api</groupId>    <artifactId>00-api</artifactId>    <version>1.0-SNAPSHOT</version>     <properties>        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>        <maven.compiler.source>1.8</maven.compiler.source>        <maven.compiler.target>1.8</maven.compiler.target>    </properties> </project>

四、創(chuàng)建提供者(自建Spring容器)00-api-provider

(1)創(chuàng)建工程

創(chuàng)建一個(gè)Maven的Java工程,并命名為00-api-provider

(2) 在pom中導(dǎo)入依賴

主要包含三類依賴:

業(yè)務(wù)接口依賴
Dubbo依賴(2.7.0版本)
Spring依賴(4.3.16版本)

<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0"         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0</modelVersion>     <groupId>00-api-provider</groupId>    <artifactId>00-api-provider</artifactId>    <version>1.0-SNAPSHOT</version>     <properties>        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>        <maven.compiler.source>1.8</maven.compiler.source>        <maven.compiler.target>1.8</maven.compiler.target>        <!-- 自定義版本號(hào) -->        <spring-version>4.3.16.RELEASE</spring-version>    </properties>     <dependencies>        <!--業(yè)務(wù)接口工程依賴-->        <dependency>            <groupId>00-api</groupId>            <artifactId>00-api</artifactId>            <version>1.0-SNAPSHOT</version>        </dependency>         <!-- dubbo依賴 -->        <dependency>            <groupId>org.apache.dubbo</groupId>            <artifactId>dubbo</artifactId>            <version>2.7.2</version>        </dependency>         <!-- Spring依賴 -->        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-beans</artifactId>            <version>${spring-version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-core</artifactId>            <version>${spring-version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-context</artifactId>            <version>${spring-version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-expression</artifactId>            <version>${spring-version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-aop</artifactId>            <version>${spring-version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-aspects</artifactId>            <version>${spring-version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-tx</artifactId>            <version>${spring-version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-jdbc</artifactId>            <version>${spring-version}</version>        </dependency>        <!-- commons-logging依賴 -->        <dependency>            <groupId>commons-logging</groupId>            <artifactId>commons-logging</artifactId>            <version>1.2</version>        </dependency>    </dependencies>  </project>

(3) 定義接口實(shí)現(xiàn)類

(4) 定義spring-provider配置文件

在src/main/resources下定義spring-provider.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://dubbo.apache.org/schema/dubbo"       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://dubbo.apache.org/schema/dubbo http://dubbo.apache.org/schema/dubbo/dubbo.xsd">     <!--指定當(dāng)前工程在管控平臺(tái)中的名稱-->    <dubbo:application name="01-provider"/>     <!--指定注冊(cè)中心:不使用注冊(cè)中心-->    <dubbo:registry address="N/A"/>     <!--注冊(cè)業(yè)務(wù)接口實(shí)現(xiàn)類,它是真正的服務(wù)提供者-->    <bean id="someService" class="com.dubbo.provider.SomeServiceImpl"/>     <!--服務(wù)暴露-->    <dubbo:service interface="com.dubbo.provider.SomeService" ref="someService"/></beans>

(5) 定義測(cè)試類

在/src/test/java中創(chuàng)建測(cè)試類RunProvider

五、創(chuàng)建提供者(Main啟動(dòng)) 01-api-provider

使用自建Spring容器方式是比較浪費(fèi)資源的。容器的作用僅僅就是創(chuàng)建一個(gè)單例的提供者對(duì)象,其本身并不需要 Tomcat 或 JBoss 等 Web 容器的功能。如果硬要用 Web 容器去加載服務(wù)提供方,就增加了代碼的復(fù)雜性,也浪費(fèi)了資源。
Dubbo提供了一個(gè)Main.main()方法可以直接創(chuàng)建并啟動(dòng)Provider,其底層僅僅是加載了一個(gè)簡(jiǎn)單的用于暴露服務(wù)的Spring容器。該方式要求Spring配置文件必須要放到類路徑下的META-INF/spring目錄中,Spring配置文件名稱無所謂

(1)工程創(chuàng)建

復(fù)制00-api-provider工程,并修改其工程名01-api-provider

(2) 創(chuàng)建目錄并移動(dòng)配置文件

在resources目錄中創(chuàng)建META-INF/spring目錄,并將spring-provider.xml配置文件拖入其中

(3) 修改啟動(dòng)類

六、創(chuàng)建消費(fèi)者01-consumer

(1) 創(chuàng)建工程

創(chuàng)建一個(gè)Maven的Java工程,并命名為01-consumer

(2) 在pom中導(dǎo)入依賴

該工程的依賴與Provider中的完全相同,直接復(fù)制來就可以
(3) 定義spring-consumer配置文件

(4) 定義消費(fèi)者類

七、效果

(1)啟動(dòng)提供者

(2)消費(fèi)者消費(fèi)

總結(jié)

以上是生活随笔為你收集整理的Dubbo直连方式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。