久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

使用 Apache Dubbo 實(shí)現(xiàn)遠(yuǎn)程通信(微服務(wù)架構(gòu))

瀏覽:90日期:2023-03-07 14:40:04
目錄
  • 前言
  • 1. Dubbo 基礎(chǔ)知識(shí)
    • 1.1 Dubbo 是什么
    • 1.2 Dubbo 的架構(gòu)圖
    • 1.3 Spring Cloud 與 Dubbo 的區(qū)別
    • 1.4 Dubbo 的特點(diǎn)
    • 1.5 Dubbo 的 6 種容錯(cuò)模式容錯(cuò)模式
    • 1.7 主機(jī)綁定規(guī)則
  • 2. 構(gòu)建 Dubbo 服務(wù)提供方
    • 2.1 構(gòu)建服務(wù)接口模塊
    • 2.2 添加 pom.xml 依賴文件
    • 2.3 修改 application.yml 配置文件
    • 2.4 在主程序類上添加注解
    • 2.5 實(shí)現(xiàn) 2.1 定義的接口
  • 3. 構(gòu)建 Dubbo 服務(wù)消費(fèi)方
    • 3.1 添加 pom.xml 依賴文件同服務(wù)提供方;
    • 3.2 修改 application.yml 配置文件
    • 3.3 修改業(yè)務(wù)類
  • 4. 在消費(fèi)者端使用 Mock 配置實(shí)現(xiàn)服務(wù)降級(jí)
    • 4.1 為接口實(shí)現(xiàn)一種服務(wù)降級(jí)方法
    • 4.2 給 @Reference 注解增加 mock 參數(shù)
  • 5. Dubbo 使用 Zookeeper 作為注冊(cè)中心(Spring Boot)
    • 5.1 下載 Zookeeper 服務(wù)器
    • 5.2 引入 pom.xml 依賴文件服務(wù)提供者與服務(wù)消費(fèi)者需要引入的依賴相同;
    • 5.3 服務(wù)提供者
      • 5.3.1 修改 application.yml 配置文件
      • 5.3.2 在主程序類上添加注解
      • 5.3.3 編寫業(yè)務(wù)類
    • 5.4 服務(wù)消費(fèi)者
      • 5.4.1 修改 application.yml 配置文件
      • 5.4.2 在主程序類上添加注解
      • 5.4.3 編寫業(yè)務(wù)類
  • 6. Dubbo 使用 Nacos 作為注冊(cè)中心(Spring Boot)
    • 6.1 下載 Nacos 服務(wù)器
      • 6.2 工程結(jié)構(gòu)
        • 6.3 引入 pom.xml 依賴文件
          • 6.4 修改 application.yml 配置文件
            • 6.5 在主程序類上添加注解
              • 6.6 編寫業(yè)務(wù)類實(shí)現(xiàn)
                • 6.7 啟動(dòng)測(cè)試
                • 7. Dubbo 使用 Nacos 作為注冊(cè)中心(Spring Cloud)
                  • 7.1 下載 Nacos 服務(wù)器
                    • 7.2 工程結(jié)構(gòu)
                      • 7.3 添加 pom.xml 依賴
                        • 7.4 添加 application.yml 依賴文
                          • 7.5 主程序類上無(wú)需額外注解
                            • 7.6 編寫業(yè)務(wù)類實(shí)現(xiàn)

                            前言

                            參考資料:
                            《Spring Microservices in Action》
                            《Spring Cloud Alibaba 微服務(wù)原理與實(shí)戰(zhàn)》
                            《B站 尚硅谷 SpringCloud 框架開發(fā)教程 周陽(yáng)》

                            Apache Dubbo 是一個(gè)分布式服務(wù)框架,主要實(shí)現(xiàn)多個(gè)系統(tǒng)之間的高性能、透明化調(diào)用;
                            Dubbo 相關(guān)內(nèi)容筆者之前寫過(guò)一篇入門筆記:Dubbo快速上手筆記 - 環(huán)境與配置。入門筆記強(qiáng)調(diào)的是 Dubbo 的一些基本特性,以與 Zookeeper 的整合。因此這里將重點(diǎn)放在 Dubbo 與 Spring Cloud 的聯(lián)系、區(qū)別以及整合;

                            1. Dubbo 基礎(chǔ)知識(shí)

                            1.1 Dubbo 是什么

                            • Apache Dubbo 是一個(gè)分布式服務(wù)框架,主要實(shí)現(xiàn)多個(gè)系統(tǒng)之間的高性能、透明化調(diào)用;
                            • 簡(jiǎn)單來(lái)說(shuō)它就是一個(gè) RPC 框架,但是和普通的 RPC 框架不同的是,它提供了服務(wù)治理功能,比如服務(wù)注冊(cè)、監(jiān)控、路由、容錯(cuò)等;

                            1.2 Dubbo 的架構(gòu)圖

                            1.3 Spring Cloud 與 Dubbo 的區(qū)別

                            參考:https://segmentfault.com/a/1190000038320266

                            比較項(xiàng)DubboSpring Cloud通信協(xié)議基于 TCP 協(xié)議傳輸,使用 Netty 配合以Hession序列化完成RPC通信基于 HTTP 協(xié)議 + REST 接口調(diào)用遠(yuǎn)程過(guò)程的通信服務(wù)調(diào)用方式RPCREST API定位SOA 時(shí)代的產(chǎn)物微服務(wù)架構(gòu)時(shí)代關(guān)注點(diǎn)服務(wù)的重用性及解決信息孤島問(wèn)題;服務(wù)治理解耦,降低業(yè)務(wù)之間的耦合度;微服務(wù)治理整套方案模塊服務(wù)注冊(cè)中心、服務(wù)提供者、服務(wù)消費(fèi)者、管控中心分布式一站式框架
                            • HTTP 請(qǐng)求會(huì)有更大的報(bào)文,占的帶寬也會(huì)更多。但是 REST 相比 RPC 更為靈活,服務(wù)提供方和調(diào)用方的依賴只依靠一紙契約,不存在代碼級(jí)別的強(qiáng)依賴,這在強(qiáng)調(diào)快速演化的微服務(wù)環(huán)境下,顯得更為合適;
                            • 模塊組件的具體比較如下:
                            組件DubboSpring Cloud (Netflix)注冊(cè)中心以前是 Zookeeper,現(xiàn)在推廣 NacosSpring Cloud Eureka服務(wù)監(jiān)控Dubbo-monitorSpring Boot Admin熔斷器6種容錯(cuò)模式Spring Cloud Hystrix負(fù)載均衡4 種負(fù)載均衡策略Spring Cloud Ribbon服務(wù)降級(jí)Mock 機(jī)制Hystrix 的 @HystrixCommand 注解網(wǎng)關(guān)無(wú)Spring Cloud Zuul配置無(wú)Spring Cloud Config服務(wù)跟蹤無(wú)Spring Cloud Sleuth數(shù)據(jù)流無(wú)Spring Cloud Stream批量任務(wù)無(wú)Spring Cloud Task消息總線無(wú)Spring Cloud Bus

                            1.4 Dubbo 的特點(diǎn)

                            • 支持多種協(xié)議的服務(wù)發(fā)布,默認(rèn)是 dubbo://,還可以支持 rest://、webservice://、thrift:// 等;
                            • 支持多種不同的注冊(cè)中心,如:Nacos、ZooKeeper、Redis,未來(lái)還將會(huì)支持 Consul、Eureka、Etcd 等;
                            • 支持多種序列化技術(shù),如:avro、fst、fastjson、hessian2、kryo 等;
                            • 在服務(wù)治理方面的功能非常完善,如:集群容錯(cuò)、服務(wù)路由、負(fù)載均衡、服務(wù)降級(jí)、服務(wù)限流、服務(wù)監(jiān)控、安全驗(yàn)證等;
                            • 中文文檔;

                            1.5 Dubbo 的 6 種容錯(cuò)模式容錯(cuò)模式

                            容錯(cuò)模式模式名稱說(shuō)明適用場(chǎng)景Failover Cluster【默認(rèn)】失敗自動(dòng)切換當(dāng)服務(wù)調(diào)用失敗后,會(huì)切換到集群中的其他機(jī)器進(jìn)行重試,默認(rèn)重試次數(shù)為2,通過(guò)屬性 retries=2 可以修改次數(shù)通常用于讀操作(查),因?yàn)槭聞?wù)型操作會(huì)帶來(lái)數(shù)據(jù)重復(fù)問(wèn)題Failfast Cluster快速失敗當(dāng)服務(wù)調(diào)用失敗后,立即報(bào)錯(cuò),也就是只發(fā)起一次調(diào)用通常用于一些冪等的寫操作(增刪改),比如新增數(shù)據(jù);以避免在結(jié)果不確定的情況下導(dǎo)致數(shù)據(jù)重復(fù)插入的問(wèn)題Failsafe Cluster失敗安全出現(xiàn)異常時(shí),直接忽略異常使用 Failover Cluster(retries="0"),應(yīng)對(duì)(增刪改)操作Failback Cluster失敗后自動(dòng)回復(fù)服務(wù)調(diào)用出現(xiàn)異常時(shí),在后臺(tái)記錄這條失敗的請(qǐng)求定時(shí)重發(fā)適合用于消息通知操作,保證這個(gè)請(qǐng)求一定發(fā)送成功Forking Cluster并行提交并行調(diào)用集群中的多個(gè)服務(wù),只要其中一個(gè)成功就返回。可以通過(guò)forks=2來(lái)設(shè)置最大并行數(shù) Broadcast Cluster廣播通知廣播調(diào)用所有的服務(wù)提供者,任意一個(gè)服務(wù)報(bào)錯(cuò)則表示服務(wù)調(diào)用失敗通常用于通知所有的服務(wù)提供者更新緩存或者本地資源信息
                            • 可以自行擴(kuò)展容錯(cuò)模式;
                            • 配置也很簡(jiǎn)單,在 @Service 接口里添加一個(gè) cluster 參數(shù)即可;
                            @Service(cluster = "failfast") //更改容錯(cuò)方式為快速失敗public class TestServiceImpl implements TestService {	@Override	public String test() {	    ...	}}

                            1.6 Dubbo 的 4 種負(fù)載均衡策略

                            負(fù)載均衡策略策略名稱說(shuō)明Random LoadBalance隨機(jī)算法可以針對(duì)性能較好的服務(wù)器設(shè)置較大的權(quán)重值,權(quán)重值越大,隨機(jī)的概率也會(huì)越大RoundRobin LoadBalance輪詢按照公約后的權(quán)重設(shè)置輪詢比例LeastActive LoadBalance最少活躍調(diào)用處理較慢的節(jié)點(diǎn)將會(huì)收到更少的請(qǐng)求ConsistentHash LoadBalance一致性Hash相同參數(shù)的請(qǐng)求總是發(fā)送到同一個(gè)服務(wù)提供者
                            • 可以基于 Dubbo 中的 SPI 機(jī)制來(lái)擴(kuò)展負(fù)載均衡策略;
                            • 配置也很簡(jiǎn)單,在 @Service 接口里添加一個(gè) loadbalance 參數(shù)即可;
                            @Service(loadbalance = "roundrobin") //更改負(fù)載均衡策略為輪詢public class TestServiceImpl implements TestService {	@Override	public String test() {	    ...	}}

                            1.7 主機(jī)綁定規(guī)則

                            • 主機(jī)綁定表示的是 Dubbo 服務(wù)對(duì)外發(fā)布的 IP 地址,默認(rèn)情況下 Dubbo 會(huì)按照以下順序來(lái)查找并綁定主機(jī) IP 地址:
                              • 查找環(huán)境變量中 DUBBO_IP_TO_BIND 屬性配置的 IP 地址;
                              • 查找 dubbo.protocol.host 屬性配置的 IP 地址,默認(rèn)是空,如果沒(méi)有配置或者IP地址不合法,則繼續(xù)往下查找;
                              • 通過(guò) LocalHost.getHostAddress 獲取本機(jī) IP 地址,如果獲取失敗,則繼續(xù)往下查找;
                              • 如果配置了注冊(cè)中心的地址,則使用 Socket 通信連接到注冊(cè)中心的地址后,使用 for 循環(huán)通過(guò) socket.getLocalAddress().getHostAddress() 掃描各個(gè)網(wǎng)卡獲取網(wǎng)卡 IP 地址;
                            • 獲取的 IP 地址并不是寫入注冊(cè)中心的地址。默認(rèn)情況下,寫入注冊(cè)中心的 IP 地址優(yōu)先選擇環(huán)境變量中 DUBBO_IP_TO_REGISTRY 屬性配置的 IP 地址。在這個(gè)屬性沒(méi)有配置的情況下,才會(huì)選取前面獲得的 IP 地址并寫入注冊(cè)中心;
                            • 問(wèn)題:使用默認(rèn)的主機(jī)綁定規(guī)則,可能會(huì)存在獲取的 P 地址不正確的情況;
                              • 原因:Dubbo 檢測(cè)本地 IP 地址的策略是先調(diào)用 LocalHost.getHostAddress,這個(gè)方法的原理是通過(guò)獲取本機(jī)的 hostname 映射 IP 地址,如果它指向的是一個(gè)錯(cuò)誤的 IP 地址,那么這個(gè)錯(cuò)誤的地址將會(huì)作為服務(wù)發(fā)布的地址注冊(cè)到 ZooKeeper 節(jié)點(diǎn)上;
                              • 解決方案
                                • /etc/hosts 中配置機(jī)器名對(duì)應(yīng)正確的 IP 地址映射;
                                • 在環(huán)境變量中添加 DUBBO_IP_TO_BIND 或者 DUBBO_IP_TO_REGISTRY 屬性,Value 值為綁定的主機(jī)地址;
                                • 通過(guò) dubbo.protocolhost 設(shè)置主機(jī)地址;

                            2. 構(gòu)建 Dubbo 服務(wù)提供方

                            • 同樣,這里使用 Zookeeper,就需要先下載 Zookeeper 服務(wù)器:詳情請(qǐng)見(jiàn)筆者的另一篇文章:apache zookeeper使用方法實(shí)例詳解;

                            2.1 構(gòu)建服務(wù)接口模塊

                            • Dubbo 官方推薦把服務(wù)接口打成 Jar 包發(fā)布到倉(cāng)庫(kù)上;
                            • 這樣服務(wù)消費(fèi)者可以依賴該 Jar 包,通過(guò)接口調(diào)用方式完成遠(yuǎn)程通信。對(duì)于服務(wù)提供者來(lái)說(shuō),也需要依賴該 Jar 包完成接口的實(shí)現(xiàn);
                            • 做法如下:
                            • 新建 spring-cloud-dubbo-sample-api 模塊,添加 pom.xml 依賴文件;
                            <!-- Dubbo --><dependency>    <groupId>org.apache.dubbo</groupId>    <artifactId>dubbo</artifactId>    <version>${dubbo.version}</version></dependency>

                            在 service 包下新建接口:

                            public interface TestService {	String test(String message);}

                            執(zhí)行 mvn install 命令將接口 jar 包安裝到本地倉(cāng)庫(kù);

                            2.2 添加 pom.xml 依賴文件

                            <!-- Spring Cloud 核心包--><dependency>    <groupId>org.springframework.cloud</groupId>    <artifactId>spring-cloud-starter</artifactId></dependency><!-- Dubbo Spring Cloud Starter -->    <groupId>com.alibaba.cloud</groupId>    <artifactId>spring-cloud-starter-dubbo</artifactId><!-- Sample API 接口聲明-->    <artifactId>spring-cloud-dubbo-sample-api</artifactId><!-- Spring Cloud Nacos Service Discovery -->    <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>

                            2.3 修改 application.yml 配置文件

                            spring:  application:    name: spring-cloud-dubbo-provider  cloud:    zookeeper:      discovery:register: true  #表示該服務(wù)要注冊(cè)進(jìn)注冊(cè)中心      connect-string: localhost:2181  #zookeeper 服務(wù)器位置dubbo:       protocol:    name: dubbo    port: 20880

                            2.4 在主程序類上添加注解

                            • @DubboComponentScan:掃描主程序類所在包及其子包下的所有注解,將 @Servicr 注解下類注冊(cè)進(jìn)容器里;

                            2.5 實(shí)現(xiàn) 2.1 定義的接口

                            @Servicepublic class TestServiceImpl implements TestService {    @Value("${dubbo.application.name}")    private String serviceName;    	@Override	public String test(String message) {		return serviceName;	}}
                            • 可以在 @Service 注解里添加兩個(gè)屬性配置 clusterloadbalance,分別用來(lái)配置容錯(cuò)模式和負(fù)載均衡策略;
                            • 詳情請(qǐng)見(jiàn)本篇《1.5 Dubbo 的 6 種容錯(cuò)模式》和《1.6 Dubbo 的 4 種負(fù)載均衡策略》

                            3. 構(gòu)建 Dubbo 服務(wù)消費(fèi)方

                            3.1 添加 pom.xml 依賴文件同服務(wù)提供方;

                            <!-- Spring Cloud 核心包--><dependency>    <groupId>org.springframework.cloud</groupId>    <artifactId>spring-cloud-starter</artifactId></dependency><!-- Dubbo Spring Cloud Starter -->    <groupId>com.alibaba.cloud</groupId>    <artifactId>spring-cloud-starter-dubbo</artifactId><!-- Sample API 接口聲明-->    <artifactId>spring-cloud-dubbo-sample-api</artifactId><!-- Spring Cloud Nacos Service Discovery -->    <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>

                            3.2 修改 application.yml 配置文件

                            spring:  application:    name: spring-cloud-dubbo-consumer  cloud:    zookeeper:      discovery:register: false #表示該服務(wù)不要注冊(cè)進(jìn)注冊(cè)中心      connect-string: localhost:2181  dubbo:       cloud:    subscribed-services: spring-cloud-dubbo-provider  #表示服務(wù)調(diào)用者訂閱的服務(wù)提供方的應(yīng)用名稱列表。默認(rèn)值為“*”,不推薦使用默認(rèn)值

                            3.3 修改業(yè)務(wù)類

                            在服務(wù)類中使用 @Reference 注解注入 TestService 即可;

                            @RestControllerpublic class TestController{    @Reference     private TestService testService;        @GetMapping("/message")    public String testController(){return testService.test("message");}

                            4. 在消費(fèi)者端使用 Mock 配置實(shí)現(xiàn)服務(wù)降級(jí)

                            • 在本示例中將對(duì) 2.1 中定義的 TestService 接口配置服務(wù)降級(jí)策略;
                            • 降級(jí)策略的配置都是在基于服務(wù)消費(fèi)者之上的;

                            4.1 為接口實(shí)現(xiàn)一種服務(wù)降級(jí)方法

                            public class MockTestService implements TestService {	@Override	public String test(String message) {		return "當(dāng)前無(wú)法訪問(wèn)";	}}

                            4.2 給 @Reference 注解增加 mock 參數(shù)

                            @RestControllerpublic class TestController{    @Reference(mock = "com.dlhjw.springcloud.mock.MockTestService", cluster="failfast")    private TestService testService;        @GetMapping("/message")    public String testController(){return testService.test("message");}
                            • 在 TestController 類中修改 @Reference 注解增加 mock 參數(shù);
                            • 其中設(shè)置了屬性 cluster="failfast",因?yàn)槟J(rèn)的容錯(cuò)策略會(huì)發(fā)起兩次重試,等待的時(shí)間較長(zhǎng);

                            5. Dubbo 使用 Zookeeper 作為注冊(cè)中心(Spring Boot)

                            • 這里僅使用到了 Spring Boot 的自動(dòng)配置;
                            • 有兩種配置方式,一種是使用 .xml,另一種是使用 .yml;
                            • .xml 的配置詳情請(qǐng)見(jiàn)筆者的另一篇文章:Dubbo | Dubbo快速上手筆記 - 環(huán)境與配置;

                            5.1 下載 Zookeeper 服務(wù)器

                            Zookeeper 服務(wù)器的下載詳情請(qǐng)見(jiàn)筆者的另一篇文章:apache zookeeper使用方法實(shí)例詳解

                            5.2 引入 pom.xml 依賴文件服務(wù)提供者與服務(wù)消費(fèi)者需要引入的依賴相同;

                            <!-- Zookeeper 相關(guān)依賴 --><dependency>    <groupId>org.apache.zookeeper</groupId>    <artifactId>zookeeper</artifactId>    <version>3.5.3-beta</version></dependency><dependency>    <groupId>org.apache.curator</groupId>    <artifactId>curator-framework</artifactId>    <version>4.0.1</version></dependency><dependency>    <groupId>org.apache.curator</groupId>    <artifactId>curator-recipes</artifactId>    <version>4.0.1</version></dependency><!-- Dubbo 相關(guān)依賴 --><dependency>    <groupId>org.apache.dubbo</groupId>    <artifactId>dubbo-spring-boot-starter</artifactId>    <version>2.7.5</version></dependency><!-- Spring Boot 依賴 --><dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter</artifactId></dependency>

                            5.3 服務(wù)提供者

                            5.3.1 修改 application.yml 配置文件

                            spring:  application:    name: springboot-dubbo-demo dubbo:  #服務(wù)提供方的信息  application:    name: springboot-provider        protocol:    name: dubbo    port: 20880  registry:    address: zookeeper://localhost:2181  #zookeeper地址  #scan:    #base-packages: com.dlhjw.dubbo.service.impl  #指定 Dubbo 服務(wù)實(shí)現(xiàn)類的掃描基準(zhǔn)包,作用等同于 主程序類上的 @DubboComponentScan

                            5.3.2 在主程序類上添加注解

                            • @DubboComponentScan:作用同 Spring Boot 的 @ComponentScan,不過(guò)這里要掃描 Dubbo 提供的 @Service 注解;
                            • @DubboComponentScan(basePackages = "com.dlhjw.dubbo.service.impl")
                            • 如果上面 application 中已經(jīng)做了配置,這里可以不用添加;

                            5.3.3 編寫業(yè)務(wù)類

                            創(chuàng)建接口及其實(shí)現(xiàn)類:

                            public interface TestService {    void testDubbo();}
                            @Service(version = "1.0.0",timeout = 3000)public class TestServiceImpl implements TestService{    @Override    public void testDubbo() {    }}

                            注意:@Service 注解是 com.alibaba.dubbo.config.annotation.Service 包下的;

                            5.4 服務(wù)消費(fèi)者

                            5.4.1 修改 application.yml 配置文件

                            dubbo:  #服務(wù)消費(fèi)方的信息  application:    name: springboot-consumer   registry:    #zookeeper地址    address: zookeeper://localhost:2181

                            5.4.2 在主程序類上添加注解

                            5.4.3 編寫業(yè)務(wù)類

                            這里直接在 controller 接口里直接調(diào)用服務(wù)提供者提供的 TestService 即可;

                            @Reference(version = "1.0.0",timeout = 300)private TestService testService;

                            @Reference 注解可以獲得一個(gè)遠(yuǎn)程代理對(duì)象;

                            6. Dubbo 使用 Nacos 作為注冊(cè)中心(Spring Boot)

                            • 這里僅使用到了 Spring Boot 的自動(dòng)配置;
                            • 這里僅提供服務(wù)提供者的示例,服務(wù)消費(fèi)者類似;

                            6.1 下載 Nacos 服務(wù)器

                            Nacos 服務(wù)器的下載詳情請(qǐng)見(jiàn)筆者的另一篇文章:apache zookeeper使用方法實(shí)例詳解

                            6.2 工程結(jié)構(gòu)

                            • 新建一個(gè)父工程 spring-cloud-nacos-sample,包含兩個(gè)模塊:nacos-sample-api 和 nacos-sample-provider;
                            • 在 nacos-sample-api 中聲明接口;
                            public interface IHelloService{    String sayHello(String name);}

                            6.3 引入 pom.xml 依賴文件

                            在 nacos-sample-provider 中添加依賴文件:

                            <!-- 接口定義類 --><dependency>  <groupId>com.gupaoedu.book.nacos</groupId>  <version>1.0-SNAPSHOT</version>  <artifactId>nacos-sample-api</artifactId></dependency><!-- Nacos 的 starter 組件 --><dependency>  <groupId>com.alibaba.boot</groupId>  <artifactId>nacos-discovery-spring-boot-starter</artifactId>  <version>0.2.4</version>  <exclusions>    <exclusion>      <groupId>com.alibaba.spring</groupId>      <artifactId>spring-context-support</artifactId>    </exclusion>  </exclusions></dependency><!-- Dubbo 的 starter 組件 --><dependency>  <groupId>org.apache.dubbo</groupId>  <artifactId>dubbo-spring-boot-starter</artifactId>  <version>2.7.5</version></dependency>

                            6.4 修改 application.yml 配置文件

                            dubbo:  application:    name: spring-boot-dubbo-nacos-sample   registry:    address: nacos://127.0.0.1:8848  #基于 Nacos 協(xié)議  protocol:     name: dubbo    port: 20880

                            6.5 在主程序類上添加注解

                            @DubboComponentScan:dubbo 的包掃描注解;

                            6.6 編寫業(yè)務(wù)類實(shí)現(xiàn)

                            6.2 中定義的接口;

                            @Service public class HelloServiceImpl implements IHelloService{    @Override     public String sayHello(String name){return "He1lo World:"+name;    }

                            6.7 啟動(dòng)測(cè)試

                            啟動(dòng)服務(wù),訪問(wèn) Nacos 控制臺(tái),進(jìn)入“服務(wù)管理” -> “服務(wù)列表”,可以看到所有注冊(cè)在 Nacos 上的服務(wù);

                            7. Dubbo 使用 Nacos 作為注冊(cè)中心(Spring Cloud)

                            這里僅提供服務(wù)提供者的示例,服務(wù)消費(fèi)者類似;

                            7.1 下載 Nacos 服務(wù)器

                            Nacos 服務(wù)器的下載詳情請(qǐng)見(jiàn)筆者的另一篇文章:apache zookeeper使用方法實(shí)例詳解

                            7.2 工程結(jié)構(gòu)

                            • 新建一個(gè)父工程 spring-cloud-nacos-sample,包含兩個(gè)模塊:spring-cloud-nacos-sample-api 和 spring-cloud-nacos-sample-provider;
                            • 在 nacos-sample-api 中聲明接口;
                            public interface IHelloService{    String sayHello(String name);}

                            7.3 添加 pom.xml 依賴

                            在父工程中顯示聲明依賴的指定版本;

                            <dependency>  <groupId>org.springframework.cloud</groupId>  <artifactId>spring-cloud-dependencies</artifactId>  <version>Greenwich.SR2</version>  <type>pom</type>  <scope>import</scope></dependency><dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-dependencies</artifactId>  <version>2.1.11.RELEASE</version>  <type>pom</type>  <scope>import</scope></dependency><dependency>  <groupId>com.alibaba.cloud</groupId>  <artifactId>spring-cloud-alibaba-dependencies</artifactId>  <version>2.1.1.RELEASE</version>  <type>pom</type>  <scope>import</scope></dependency>

                            在 spring-cloud-nacos-sample-provider 中添加依賴文件:

                            <!-- Spring Cloud 核心包 --><dependency>  <groupId>org.springframework.cloud</groupId>  <artifactId>spring-cloud-starter</artifactId>  <exclusions>    <exclusion>      <groupId>org.springframework.cloud</groupId>      <artifactId>spring-cloud-context</artifactId>    </exclusion>  </exclusions></dependency><!-- Spring Cloud 的 Dubbo 依賴 -->  <groupId>com.alibaba.cloud</groupId>  <artifactId>spring-cloud-starter-dubbo</artifactId><!-- api 模塊 -->  <groupId>com.gupaoedu.book.springcloud</groupId>  <artifactId>spring-cloud-dubbo-sample-api</artifactId>  <version>1.0-SNAPSHOT</version><!-- 基于 Nacos 的服務(wù)注冊(cè)與發(fā)現(xiàn) -->  <artifactId>spring-cloud-alibaba-nacos-discovery</artifactId>  <artifactId>spring-cloud-context</artifactId>  <version>2.1.1.RELEASE</version>

                            7.4 添加 application.yml 依賴文

                            件與 Spring Boot 這整合方式的主要區(qū)別就在 pom.xml 配置文件和 application.yml 依賴文件;

                            spring:   application:     name: spring-cloud-nacos-sample   cloud:     nacos:       discovery:server-addr: 127.0.0.1:8848  #Nacos 服務(wù)注冊(cè)中心地址dubbo:   scan:     base-packages: com.gupaoedu.book.nacos.bootstrap  #功能等同于 @DubboComponentScan     protocol:     name: dubbo    port: 20880  registry:    address: spring-cloud://localhost  #將服務(wù)掛載到 Spring Cloud 注冊(cè)中心

                            7.5 主程序類上無(wú)需額外注解

                            7.6 編寫業(yè)務(wù)類實(shí)現(xiàn)

                            7.2 中定義的接口即可;

                            @Service public class HelloServiceImpl implements IHelloService{    @Override     public String sayHello(String name){return "He1lo World:"+name;    }}

                            到此這篇關(guān)于使用 Apache Dubbo 實(shí)現(xiàn)遠(yuǎn)程通信(微服務(wù)架構(gòu))的文章就介紹到這了,更多相關(guān)Apache Dubbo 遠(yuǎn)程通信內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

                            標(biāo)簽: Linux Apache
                            主站蜘蛛池模板: 午夜精品福利在线观看 | 91麻豆产精品久久久 | 99视频在线| 免费国产黄网站在线观看视频 | 午夜家庭影院 | 国产91在线播放精品91 | 一区视频在线 | 日本不卡视频 | 一区二区三区高清不卡 | 91成人免费看片 | 久久久91精品国产一区二区三区 | 日本中文字幕一区二区 | 成人午夜视频在线观看 | 狠狠av | 国产美女高潮 | 日本不卡免费新一二三区 | 色999精品| 欧美日韩国产一区二区在线观看 | 国产成人精品亚洲日本在线观看 | 成人永久免费视频 | 亚洲精品日韩激情欧美 | 伊人久操 | 欧美日本韩国一区二区 | 91视频在线观看 | 久久精品一区二区国产 | 青青草久久爱 | 亚洲成人中文字幕 | 亚洲一区二区三区免费观看 | 99爱视频 | 播放毛片 | 亚洲精品久久久久久下一站 | 人人爽日日爽 | 精品久久久久久国产 | 亚洲一区二区三区视频免费观看 | 成人片在线播放 | 欧美一区中文字幕 | 亚洲成人中文字幕 | 午夜私人影院 | 日韩另类 | 黄色片网站在线观看 | 精品美女在线观看视频在线观看 | 欧美精品一区二 | 五月婷婷天 | 日本在线视频一区二区 | 91精品亚洲| 成人免费xxx在线观看 | 欧美一区二区三区在线视频观看 | 一级毛片免费在线 | 国产精久久| 日韩一区二区不卡 | 成人黄色av | 免费一区二区三区 | 99精品国产高清在线观看 | 性视频一区二区 | 国产一区二区在线免费观看 | 久久99久久99精品免观看粉嫩 | 国产精品久久久久久久岛一牛影视 | 成人免费小视频 | 欧美中文日韩 | 国产99久久久国产精品 | 一区二区三区国产精品 | 亚洲天堂色2017 | 欧美成人精品激情在线观看 | 亚洲综合电影 | 国产视频精品视频 | 精品久久久网站 | 欧美久热 | 亚洲人网站 | 欧美综合婷婷 | 亚洲一区 中文字幕 | 久在线视频| 国产视频久久 | 狠狠操中文字幕 | www日本高清视频 | 国产精品欧美久久久久一区二区 | 天天舔天天干天天操 | 亚洲 欧美 综合 | 毛片国产 | 午夜亚洲福利 | 男人的天堂在线视频 | 国产一区在线视频 | 国产黄色精品 | 天堂中文在线视频 | 91久久精品一区 | 色婷婷一区二区三区四区 | 日韩精品一区二区三区在线观看 | 9久久精品 | 日韩电影在线 | 日日干日日操 | 亚洲一区综合 | 操操网站 | 爱色av| 欧美日韩中文字幕在线播放 | 日韩激情一区二区 | 日本黄色大片免费 | www精品| 精品日韩在线 | 亚洲二区在线播放 | 亚洲欧洲精品视频在线观看 | 在线精品亚洲欧美日韩国产 | 精品99久久久久久 | 91在线观看视频 | 中文在线a在线 | 在线精品一区二区 | 国产女人和拘做受视频 | 国产精品久久久久永久免费观看 | 精品国产福利 | 亚洲成人免费电影 | 日本综合色 | 久久夜视频 | 不卡一区 | 91精品久久久久久久99 | 久久成人国产精品 | 久草在线高清 | 久久久久久黄 | 天天狠狠操 | 在线国产一区二区 | 欧美日本一区 | 美女视频黄a| 精品欧美一区二区三区久久久 | 国产精品一区二区三区四区 | 日韩第一页 | 日本午夜在线 | 黄色成人在线 | 亚洲一区二区三区高清 | 欧美日韩伊人 | 欧美午夜一区 | 亚洲成人在线观看视频 | 精品国产一区二区三区日日嗨 | 成人高清视频免费观看 | 国产成年人小视频 | 亚洲第一se情网站 | 精品久久久久一区二区三区 | 久久涩 | 国产三级精品三级 | 91精品国产综合久久婷婷香蕉 | 久久国产精品视频观看 | 一级免费黄色免费片 | 99精品国产在热久久 | 国产情侣一区二区三区 | 婷婷久久综合 | 一区二区三区视频免费在线观看 | 亚洲一二三区电影 | 亚洲精品免费看 | 9999久久久久 | 91夜夜夜| 国产一区精品视频 | 亚洲精品乱码 | 99精品欧美一区二区三区综合在线 | 国产黄色在线免费看 | 亚洲一区二区在线 | 免费久久99精品国产婷婷六月 | 色天天综合久久久久综合片 | 久久久久久综合 | 国产一区二区资源 | 国产精品一区二区精品 | 夫妻午夜影院 | 日韩欧美国产一区二区三区 | 国产高清精品一区二区三区 | 91成人免费看片 | 黄色一级片免费 | 亚洲国产高清在线 | 精品无人乱码一区二区三区 | 久久国产精品91 | 亚洲精品视频在线播放 | 精品一二区| 色综合天天天天做夜夜夜夜做 | 91免费在线播放 | 九九久久精品 | 欧美精品一区二区三区中文字幕 | 久久精品免费观看 | 欧美视频一区二区 | 蜜臀影院 | 国产精品美乳一区二区免费 | 五月天婷婷激情视频 | 综合久久99 | 国产精品一区在线 | 91精品国产综合久久福利软件 | 国产一级片在线 | 九九天堂网 | 国产日本欧美在线 | а天堂中文最新一区二区三区 | 日韩视频―中文字幕 | 黄色影片免费在线观看 | 国产精品婷婷午夜在线观看 | 亚洲精品一区二区三区蜜桃久 | av在线免费观看一区二区 | 高清成人 | 色综合天天综合网国产成人网 | 在线第一页 | 久在线| 狠狠综合久久av一区二区老牛 | www.一区| 91高清视频在线观看 | 精品久久久久久亚洲综合网 | 亚州中文| 久久免费视频9 | 97av在线 | 久久美女 | av男人的天堂网 | 在线亚洲不卡 | 狠狠操夜夜操 | 日韩网站免费观看 | 国产一区二区观看 | 国产一区二区三区在线 | 九九国产 | 国产精品久久一区 | 欧美日韩视频在线播放 | 黄色大片观看 | 国产精品久久久久aaaa九色 | 中文字幕亚洲欧美日韩在线不卡 | 久久免费视频观看 | 爱爱视频网站 | 日本丶国产丶欧美色综合 | 在线观看国产视频 | 噜噜噜在线 | 夜夜艹 | 日韩免费一区 | www.av7788.com| 亚洲成人精品久久 | 91麻豆精品国产91久久久久久久久 | 日韩 国产 在线 | 久久精品国产免费 | 亚洲国产欧美91 | 一区二区三区免费网站 | av在线免费看片 | 蜜臀av在线播放一区二区三区 | 日视频 | 亚洲成人三区 | 色欧美日韩| www中文字幕 | 羞羞视频免费看 | 嫩草懂你 | 香蕉综合久久 | 91看片网 | 91短视频版在线观看免费大全 | 日韩久久影院 | 国产精品欧美一区二区三区 | 久久久人成影片一区二区三区 | 超碰97人人人人人蜜桃 | www亚洲成人 | 国产亚洲精品精品国产亚洲综合 | 日韩视频在线免费观看 | 日韩在线免费视频 | 欧美日韩国产精品 | 国产一区精品在线 | 中文字幕精品一区 | 国产片侵犯亲女视频播放 | 四虎影视免费在线观看 | 日本jizz在线观看 | 成人在线观看中文字幕 | av大片网 | 久久福利电影 | 一级视频网站 | 欧美一区二区三 | 久久99精品国产99久久6尤 | 久久精品久久久久电影 | 欧美精品一区二区视频 | 久热精品视频在线播放 | 久久精品网 | 色网网站| 国产乱码精品一区二区三区中文 | 亚洲高清精品视频 | 午夜寂寞福利视频 | 国产一二三区在线播放 | av片免费看 | 国产精品永久在线 | 精品久久久久国产免费 | 久久中文字幕一区二区三区 | 一区二区中文字幕 | 免费看男女www网站入口在线 | 特黄特黄aaaa级毛片免费看 | 成人欧美在线视频 | 精品欧美一区二区三区久久久 | 国产欧美精品一区二区三区 | 欧美在线视频一区二区 | 中文字幕在线免费 | 国产精品国产 | 国产成人久久精品一区二区三区 | 久久99国产精一区二区三区 | 99精品国产在热久久 | 久久成 | 久久亚洲欧美日韩精品专区 | 亚洲欧美综合精品久久成人 | 亚洲国产精品一区 | 依人久久 | 精品欧美日韩 | 国产在线视频a | 天堂√在线观看一区二区 | 欧美精品区 | 久久综合九色综合欧美狠狠 | 国产2区| 国产精品久久毛片 | 日韩欧美国产一区二区 | 亚洲一区二区三 | 91高清在线| 国产三级自拍 | 91偷拍精品一区二区三区 | 国产一级免费视频 | 97精品国产 | 色婷婷久久久久swag精品 | 福利二区| 中文视频在线 | 精品国产一区二区三区性色 | 精品免费国产一区二区三区 | 久久免费精品视频 | 日日日日日 | 在线观看国产视频 | 中文字幕综合 | 不卡一区二区三区视频 | 亚洲天堂一区 | 精品亚洲一区二区三区 | 国产视频久久久久 | 亚洲视频在线观看一区二区三区 | 午夜影院在线 | 国产小视频在线观看 | 国产黄色影视 | 在线免费色视频 | 日韩视频在线观看视频 | 91网站在线看 | 国产精品久久久久久久浪潮网站 | 一级片在线播放 | a一级免费视频 | 精品中出 | 日本一区不卡 | 中文字幕在线播放一区 | 偷拍做爰吃奶视频免费看 | 曰曰操 | 国产成人精品在线 | 色女人av| 天堂资源 | 日韩手机在线 | 日韩成人免费中文字幕 | 日韩欧美国产精品综合嫩v 久久久久久国产精品高清 国产目拍亚洲精品99久久精品 | 四虎影院最新地址 | 色综合五月婷婷 | av在线免费看片 | 日韩高清在线一区 | 97精品一区二区三区 | 亚洲人成一区 | 成人欧美日韩一区二区三区 | 欧美白人做受xxxx视频 | 老牛影视av一区二区在线观看 | 少妇黄色 | 久久网站免费视频 | 日韩在线不卡 | 国产在线不卡一区 | 日本一级毛片免费看 | 色呦呦网站在线观看 | 99国产精品久久久久久久久久 | 精品国产乱码久久久久久1区二区 | 久热免费在线 | 成人免费在线视频播放 | 亚洲一二视频 | 亚洲精品成人无限看 | 国产欧美精品一区二区三区 | 毛片天堂 | 黄色片免费在线 | 免费毛片视频 | 国产免费自拍视频 | 狠狠干狠狠干 | 国产一区二区视频免费看 | 欧洲精品一区 | 欧美精品一区二区三区蜜桃视频 | 中文字幕二区三区 | 国产在线一区二区三区 | 成人免费淫片aa视频免费 | 成人在线免费观看 | 一级大片av | 91视频免费观看 | 日韩精品久久 | 久久久久综合狠狠综合日本高清 | 亚州综合一区 | 97综合色 | 午夜精品久久久久久久星辰影院 | 欧美视频网站 | 国产高清精品一区二区三区 | 久久国产亚洲 | 99久久久久 | 国产一级视频在线播放 | 国产精品视频一区二区三区四蜜臂 | 成av在线| 成人亚洲在线观看 | 夜夜夜久久久 | 在线欧美亚洲 | 日本一区二区电影 | 黄色a视频 | 99伊人 | 一区二区三区久久 | 国产综合精品一区二区三区 | 亚州成人 | 黄色天堂网 | 91.com在线 | 国产精品久久久久久久久久99 | 亚洲伦理在线 | 精品国精品国产自在久不卡 | 久久久美女 | 日日骚视频 | 免费精品视频 | 午夜精品一区二区三区在线视频 | 久久精品久久久久久久久久久久久 | 日韩黄视频 | 国产精品视频一区二区三区不卡 | 精品国产一区二区三区性色 | 久久综合一区 | 久久精品无码一区二区三区 | 国产精品久久久久久久久久久久久久久久 | 久久综合一区二区 | 老司机深夜福利在线观看 | 999久久久久久久久 国产欧美在线观看 | 国产精品无码久久久久 | 成人欧美一区二区三区在线观看 | 精一区二区 | 欧美日韩在线一区 | 日韩欧美一区二区视频 | 日本一区二区三区中文字幕 | 在线成人www免费观看视频 | 精品国产乱码一区二区三区四区 | 日韩小视频 | 午夜视频在线观看网站 | 国产激情午夜 | 亚洲一区二区三区四区五区中文 | 亚洲视频一区二区三区 | 国产日韩一区二区三区 | 狠狠插天天干 | 国产视频中文字幕 | 亚洲精品视频在线播放 | 久久青青操 | 久久精品国产77777蜜臀 | 91社影院在线观看 | 国产不卡视频 | 国产精品 日韩 | 精品九九 | 欧美麻豆| 91精品久久久久久久 | 视频在线一区 | 黄色小视频网 | 日日想日日干 | 午夜精品久久久久久久星辰影院 | 欧美亚洲高清 | 国产精品九九九 | 亚洲欧美综合精品久久成人 | 九热精品| 成人久久18免费 | 国产精品毛片久久久久久久 | 高清国产一区二区三区四区五区 | 成人精品一区二区 | 蜜月va乱码一区二区三区 | 婷婷综合激情 | 欧洲成人在线观看 | 青青久视频 | 亚洲国产伊人 | 日夜夜精品 | 欧美中文字幕在线观看 | 日韩一区二区三区在线视频 | 精品日韩视频 | 中文字幕在线观看av | 久久久高清 | 蜜桃色网 | 日韩精品一区二区三区 | 国产乱码精品一区二区三区爽爽爽 | 免费亚洲视频 | 一区二区av| 国产精品无码永久免费888 | 久久久久久久成人 | 国内精品在线视频 | 簧片免费网站 | 九一视频在线免费观看 | 精品中文字幕在线 | 欧美日韩中文字幕在线 | 国产一区二区视频在线观看 | 国产成人精品一区二 | 曰批免费视频播放免费 | 农村妇女毛片精品久久久 | 爱操在线 | 亚洲精品日韩综合观看成人91 | 国产精品一区二区三区免费 | 日本一区二区不卡视频 | 狠狠亚洲 | 午夜精品视频 | 成人精品在线视频 | 日本福利网站 | 国产一区二区三区四区在线观看 | 国产日韩在线视频 | 狠狠艹夜夜艹 | 国产欧美精品一区二区三区四区 | 欧美日韩高清在线一区 | 久久久久久久久久国产 | 欧美一级片免费看 | 国产高清一区二区 | 香蕉成人啪国产精品视频综合网 | 欧美在线综合 | 久草在线在线精品观看 | 91成人精品| 国产欧美精品一区二区三区四区 | 精品久久久久香蕉网 | 狠狠躁夜夜躁人人爽天天天天97 | 国产色网| 国产视频精品视频 | 亚洲夜幕久久日韩精品一区 | 成人h动漫免费观看网站 | 成人在线观看中文字幕 | 日韩一区二区三区福利视频 | 国产欧美精品区一区二区三区 | 欧美在线视频一区二区 | 精品国产一区二区三区日日嗨 | 精品国产欧美一区二区三区成人 | 欧美a区 | 久草.com| 中文一区二区 | 免费在线观看国产 | 欧美 中文字幕 | 日本久久精品电影 | 夜夜爽99久久国产综合精品女不卡 | 一区二区国产精品 | 国产精品女教师av久久 | 国产精品乱码一区二区三区 | 欧美日本精品 | 日日干夜夜操 | 欧美日韩一区二区三区在线观看 | 国产精品网站在线观看 | 免费看毛片的网站 | 亚洲 中文 欧美 日韩 在线观看 | 在线视频91 | 精品国产青草久久久久福利 | 一区二区在线视频 | 久久av在线| 极品一区 | 欧美精品一区二区在线观看 | 羞羞视频网站在线免费观看 | 97色在线观看免费视频 | 国产在线小视频 | 国产一级淫免费播放m | 欧美一区二区伦理片 | 国产精品69毛片高清亚洲 | 亚洲视频综合 | 天天干国产| 在线视频久久 | 日韩一区二区不卡 | 久久久久久日产精品 | 国产麻豆一区二区三区 | 免费高清一级毛片 | 怡红院免费在线视频 | 国产一区二区在线免费观看 | 日韩五码在线 | 精品一区久久 | 国产精品178页 | 色精品 | 一区 | 国产精品日韩欧美一区二区三区 | 国产精品视频一二 | 夜夜夜操操操 | av在线免费观看网站 | 国产成人精品免费视频大全最热 | 欧美一区二区三区在线看 | 亚洲精品成人在线 | 老司机在线精品视频 | 一区二区三区欧美在线 | 精品中文在线 | 日韩福利影院 | 中文字幕在线观看www | 日韩三级在线 | 在线99热| 午夜免费 | 欧美一级一区 | 亚洲精品一区在线观看 | 国产美女精品 | 欧美日韩中文在线 | 精品一区免费观看 | 成人免费av| 亚洲成av| 精品国产欧美 | 中文字幕亚洲精品 | 大香伊蕉在人线视频777 | 欧美激情在线观看 | 欧美亚洲天堂 | 成人午夜免费视频 | 青青草日韩 | 久久精品免费一区二区三区 | 国产精品久久久久久吹潮 | 成人在线播放 | 亚洲美女网站 | www.国产精品.com | 国产一页| 日韩精品一区二区三区 | av网站免费观看 | 91精品久久久久久久久中文字幕 | 国产成人免费 | 成人欧美一区二区三区在线播放 | www.国产精品 | 天天干天天干天天干天天射 | 日韩精品在线播放 | 午夜精品视频在线观看 | 97超碰人人 | 91精品国产欧美一区二区成人 | 亚洲欧美一区二区三区在线 | 久久亚洲精品中文字幕 | 国产黄色av| 黄色免费网址大全 | 成人毛片久久 | 日本三级网站在线观看 | 久久香蕉网 | 免费av在线网 | 龙珠z普通话国语版在线观看 | 黄色毛片免费看 | 亚洲成人av在线 | 久草久草久 | 久久精品国产亚卅av嘿嘿 | 亚洲精品99| 久久精品中文 | 午夜电影av | 激情久久久 | 久久久久久久一区 | 一区二区在线 | 中文字幕亚洲一区二区三区 |