欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Springboot整合Dubbo+Nacos實現(xiàn)RPC調(diào)用的示例代碼

 更新時間:2024年02月19日 09:45:38   作者:牽著貓散步的鼠鼠  
隨著互聯(lián)網(wǎng)技術(shù)的飛速發(fā)展,越來越多的企業(yè)和開發(fā)者開始關(guān)注微服務(wù)架構(gòu),Nacos是阿里巴巴開源的一個動態(tài)服務(wù)發(fā)現(xiàn)、配置管理和服務(wù)管理平臺,本文講解如何將Spring Boot與Dubbo和Nacos整合,實現(xiàn)RPC調(diào)用,需要的朋友可以參考下

前言

隨著互聯(lián)網(wǎng)技術(shù)的飛速發(fā)展,越來越多的企業(yè)和開發(fā)者開始關(guān)注微服務(wù)架構(gòu)。微服務(wù)架構(gòu)可以將一個大型的應(yīng)用拆分成多個獨立、可擴展、可維護的小型服務(wù),每個服務(wù)負責實現(xiàn)應(yīng)用的一部分功能。這種架構(gòu)方式可以提高開發(fā)效率,降低系統(tǒng)復(fù)雜度,方便團隊協(xié)作,同時也有利于資源的合理利用和彈性伸縮。

在微服務(wù)架構(gòu)中,服務(wù)之間的通信是一個關(guān)鍵問題。傳統(tǒng)的HTTP通信方式在高并發(fā)、高性能的場景下存在性能瓶頸,因此,越來越多的開發(fā)者開始采用RPC(遠程過程調(diào)用)技術(shù)來實現(xiàn)服務(wù)之間的通信。Dubbo是一款高性能、輕量級的開源Java RPC框架,它提供了豐富的服務(wù)治理功能,如服務(wù)注冊、服務(wù)發(fā)現(xiàn)、負載均衡、容錯等,被廣泛應(yīng)用于微服務(wù)架構(gòu)中。

Nacos是阿里巴巴開源的一個動態(tài)服務(wù)發(fā)現(xiàn)、配置管理和服務(wù)管理平臺,它支持基于DNS和基于RPC的服務(wù)發(fā)現(xiàn),具有跨語言、跨平臺、靈活擴展的特點。網(wǎng)上很多都是Springcloud整合Dubbo,本文講解如何將Spring Boot與Dubbo和Nacos整合,實現(xiàn)RPC調(diào)用。

快速上手

在實現(xiàn)DubboRPC服務(wù)調(diào)用時,我們首先需要一個服務(wù)注冊中心,常用的服務(wù)注冊中心有Zookeeper,Nacos等,我們這里采用Nacos,沒有部署Nacos的請先自行教程部署,這里不細講

創(chuàng)建示例項目

我們這里創(chuàng)建兩個名為ProviderDemo和ConsumerDemo的項目

導(dǎo)入依賴

整合nacos和dubbo主要需要nacos-client和dubbo這兩項依賴

        <!--這里對應(yīng)的Springboot版本為2.7.6-->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo</artifactId>
            <version>3.0.9</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
            <version>2.1.0</version>
        </dependency>

ProviderDemo的maven配置信息如下

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.luckysj</groupId>
    <artifactId>ProviderDemo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>ProviderDemo</name>
    <description>ProviderDemo</description>
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <spring-boot.version>2.7.6</spring-boot.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo</artifactId>
            <version>3.0.9</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
            <version>2.1.0</version>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
 
 
</project>

ConsumerDemo的配置信息如下

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.luckysj</groupId>
    <artifactId>ConsumerDemo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>ConsumerDemo</name>
    <description>ConsumerDemo</description>
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <spring-boot.version>2.7.6</spring-boot.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo</artifactId>
            <version>3.0.9</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
            <version>2.1.0</version>
        </dependency>
 
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
 
</project>

編寫配置

consumerDemo項目的配置如下,注意把nacos信息更改為自己的

server:
  port: 7777
 
dubbo:
  application:
    #設(shè)置應(yīng)用的名稱
    name: dubbo-springboot-consumer
    #qos監(jiān)控服務(wù)是否啟動
    qos-enable: true
    #qos監(jiān)控服務(wù)端口
    qos-port: 23456
    qos-accept-foreign-ip: false
 
  #指定使用Dubbo協(xié)議,且端口設(shè)置為-1,表示隨機分配可用端口
  protocol:
    name: dubbo
    port: -1
  registry:
    #配置注冊中心為Nacos
    id: nacos-registry
    address: nacos://nacos服務(wù)的ip:nacos服務(wù)的端口
    username: nacos賬戶
    password: nacos密碼
    parameters:
      namespace: f74484c1-02d8-4322-a50c-630bc814fe54   #nacos命名空間
    group: dubbo-demo    #nacos分組
  config-center:
    timeout: 40000 #設(shè)置服務(wù)超時時間

providerDemo項目的配置如下

server:
  port: 6666
dubbo:
  application:
    #設(shè)置應(yīng)用的名稱
    name: dubbo-springboot-provider
    qos-enable: true
    qos-port: 23444
    qos-accept-foreign-ip: false
  #指定使用Dubbo協(xié)議,且端口設(shè)置為-1,表示隨機分配可用端口
  protocol:
    name: dubbo
    port: -1
  registry:
    #配置注冊中心為Nacos
    id: nacos-registry
    address: nacos://ip:端口
    username: 賬戶
    password: 密碼
    parameters:
      namespace: f74484c1-02d8-4322-a50c-630bc814fe54   #nacos命名空間
    group: dubbo-demo    #nacos分組
  config-center:
    timeout: 40000 #設(shè)置服務(wù)超時時間

添加啟動類注解

我們要使用Dubbo服務(wù)的話需要在服務(wù)啟動類上編寫@EnableDubbo注解(提供者項目和消費者項目都需要)

編寫服務(wù)接口與服務(wù)實現(xiàn)類

我們在Provider項目中provider包下新建服務(wù)接口與實現(xiàn)類

PrintService接口內(nèi)容如下

public interface PrintService {
    public void print(String str);
}

PrintServiceImpl接口內(nèi)容如下,我們通過@DubboService注解暴露該服務(wù),

@DubboService
public class PrintServiceImpl implements PrintService {
 
    @Override
    public void print(String str) {
        System.out.println("dubbo調(diào)用打印信息為" + str);
    }
}

在服務(wù)消費方項目中也定義相同的接口

public interface PrintService {
    public void print(String str);
}

特別注意這里調(diào)用者與提供者的服務(wù)接口需要有相同的包路徑,否則無法找到對應(yīng)服務(wù),我們后續(xù)通過引入一個common項目來解決這個問題

在服務(wù)消費方項目編寫一個測試接口,使用@DubboReference注解聲明引用的服務(wù)

@RestController
@RequestMapping("/demo")
public class DemoController {
    @DubboReference //聲明服務(wù)引用
    private PrintService printService;
 
    @GetMapping("/test")
    public void testDubbo(String str){
        System.out.println("consumer開始RPC調(diào)用provider服務(wù)");
        printService.print(str);
    }
}

訪問接口,測試兩項目之間的服務(wù)調(diào)用,可以看到我們ConsumerDemo項目通過Dubbo成功的調(diào)用了ProviderDemo項目

http://localhost:7777/demo/test?str=111

引入common項目

我們上面可以發(fā)現(xiàn)提供者和消費者的服務(wù)接口必須在相同的包路徑下,十分的不優(yōu)雅,故我們可以新建一個common項目,在這個項目中定義雙方服務(wù)調(diào)用的接口,相當于定義了一種規(guī)范,兩邊都采用common中的服務(wù)接口,這樣就不會因為包路徑不同導(dǎo)致dubbo找不到對應(yīng)服務(wù)

新建common項目

打包該項目到本地(云)倉庫中,在消費者和提供者項目中引入該項目

雙方都使用common包內(nèi)的服務(wù)接口

測試接口,運行正常,結(jié)束

總結(jié)

Dubbo是一個基于Java的RPC (遠程過程調(diào)用)框架,比OpenFeign支持更多的通訊協(xié)議,且性能更高,更加適應(yīng)于大規(guī)模的分布式項目中。

以上就是Springboot整合Dubbo+Nacos實現(xiàn)RPC調(diào)用的示例代碼的詳細內(nèi)容,更多關(guān)于Springboot實現(xiàn)RPC調(diào)用的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 使用itextpdf解決PDF合并的問題

    使用itextpdf解決PDF合并的問題

    這篇文章主要介紹了使用itextpdf解決PDF合并的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 一文搞懂Java并發(fā)AQS的共享鎖模式

    一文搞懂Java并發(fā)AQS的共享鎖模式

    這篇文章主要為大家闡述AQS另外一個重要模式,共享鎖模式。共享鎖可以由多個線程同時獲取,?比較典型的就是讀鎖,感興趣的小伙伴可以了解一下
    2022-10-10
  • Springboot整合https的實例代碼

    Springboot整合https的實例代碼

    本文簡單介紹了一些密碼學(xué)的基礎(chǔ)和如何通過Springboot整合HTTPS,本文將通過實例代碼給大家詳細介紹整合過程,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • idea中springboot項目創(chuàng)建后追加依賴

    idea中springboot項目創(chuàng)建后追加依賴

    在項目創(chuàng)建的時候選擇好依賴創(chuàng)建項目,之后追加依賴不是很方便,本文就來介紹一下idea中springboot項目創(chuàng)建后追加依賴,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • LambdaQueryWrapper與QueryWrapper的使用方式

    LambdaQueryWrapper與QueryWrapper的使用方式

    這篇文章主要介紹了LambdaQueryWrapper與QueryWrapper的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • SpringMVC實現(xiàn)文件上傳與下載、攔截器、異常處理器等功能

    SpringMVC實現(xiàn)文件上傳與下載、攔截器、異常處理器等功能

    這篇文章主要給大家介紹了關(guān)于SpringMVC實現(xiàn)文件上傳與下載、攔截器、異常處理器等功能的相關(guān)資料,這些功能在我們?nèi)粘i_發(fā)中經(jīng)常會遇到,本文通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-09-09
  • Java將一個正整數(shù)分解質(zhì)因數(shù)的代碼

    Java將一個正整數(shù)分解質(zhì)因數(shù)的代碼

    這篇文章主要介紹了將一個正整數(shù)分解質(zhì)因數(shù)。例如:輸入90,打印出90=2*3*3*5,需要的朋友可以參考下
    2017-02-02
  • 如何解決java壓縮文件亂碼問題

    如何解決java壓縮文件亂碼問題

    在本篇文章中我們給大家分享的是一篇關(guān)于java壓縮文件亂碼問題的解決辦法,有需要的朋友們可以學(xué)習(xí)下。
    2019-12-12
  • Java基于鏈表實現(xiàn)棧的方法詳解

    Java基于鏈表實現(xiàn)棧的方法詳解

    這篇文章主要介紹了Java基于鏈表實現(xiàn)棧的方法,結(jié)合實例形式詳細分析了Java基于鏈表實現(xiàn)棧的原理、操作步驟與相關(guān)注意事項,需要的朋友可以參考下
    2020-03-03
  • JAVA中AES加密方法實例分析

    JAVA中AES加密方法實例分析

    這篇文章主要介紹了JAVA中AES加密方法,實例分析了java中AES加密與解密的實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07

最新評論