使用yml配置SpringBoot整合Dubbo

最近聽(tīng)聞公司的項(xiàng)目打算進(jìn)行重構(gòu),大佬們商量準(zhǔn)備使用近年大火的SpringCloud,所以在開(kāi)始學(xué)習(xí)Springcloud前急鳄,先來(lái)復(fù)習(xí)下之前項(xiàng)目中使用到的Dubbo+Zookeeper。之前的項(xiàng)目很老使用的Spring+Struct2搭建的堰酿,使用Dubbo2.5.3都是基于xml配置的疾宏,就想嘗試最新的springboot+dubbo+yml配置來(lái)搭建,并想看下老版本提供服務(wù)触创,在新的消費(fèi)者是否能獲取成功消費(fèi)坎藐。

Dubbo官方也在3年之后的17年連發(fā)了5個(gè)版本,在dubbo2.5.7之前也早已支持通過(guò)注解@Server暴露服務(wù)和@Reference消費(fèi)服務(wù)(但是我們老項(xiàng)目并沒(méi)有使用 = =)哼绑,在2.5.7中Dubbo團(tuán)隊(duì)通過(guò)增加了一個(gè)@DubboComponentScan修復(fù)了一些通過(guò)注解暴露消費(fèi)服務(wù)產(chǎn)生的Issues,具體產(chǎn)考:Dubbo 注解驅(qū)動(dòng)(Annotation-Driven) 顺饮,有興趣的同學(xué)可以看下,這篇文章主要是使用Dubbo2.5.8中提供的spring-boot-starter-dubbo來(lái)搭建Dubbo凌那。這里服務(wù)注冊(cè)中心使用Zookeeper,Zookeeper的相關(guān)問(wèn)題不清楚的同學(xué)可以自行百度吟逝,有很多資料帽蝶。

需要新建兩個(gè)maven的SpringBoot項(xiàng)目,通過(guò)SpringBoot官方提供的快速搭建項(xiàng)目的網(wǎng)站:SPRING INITIALIZR ,很容易的搭建出一個(gè)基本的SpringBoot項(xiàng)目,為了方便我們后面通過(guò)頁(yè)面測(cè)試励稳,項(xiàng)目中添加上web依賴(lài),如下圖:

快速搭建SpringBoot

  • 項(xiàng)目依賴(lài)(除了基本的SpringBoot依賴(lài)佃乘,服務(wù)提供者和消費(fèi)者的依賴(lài)都是一樣)
        <!--dubbo-springBoot依賴(lài)-->
        <dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
        </dependency>
        <!--zookeeper依賴(lài)-->
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.8</version>
        </dependency>
        <!--服務(wù)接口Jar-->
        <dependency>
            <groupId>com.aspire.aplus</groupId>
            <artifactId>sim</artifactId>
            <version>1.3.3</version>
        </dependency>

這里說(shuō)明下,最后一個(gè)依賴(lài)服務(wù)接口jar是服務(wù)接口暴露的驹尼,是自己搭建的一個(gè)項(xiàng)目打成jar放到自己鏡像庫(kù)趣避,里面主要是一些服務(wù)的interface接口。沒(méi)有自己Maven鏡像庫(kù)的同學(xué)新翎,可以把這個(gè)項(xiàng)目打成jar手動(dòng)導(dǎo)入到項(xiàng)目依賴(lài)中程帕。(所以不止倆個(gè)項(xiàng)目,還需要一個(gè)服務(wù)接口項(xiàng)目地啰。)

  • 服務(wù)接口項(xiàng)目及DemoService接口code


    需暴露服務(wù)的interface接口code

1.服務(wù)提供者dubboProvide:

  • 服務(wù)提供者yml配置文件
server:
  port: 8086

spring:
  dubbo:
    application:            #應(yīng)用配置愁拭,用于配置當(dāng)前應(yīng)用信息,不管該應(yīng)用是提供者還是消費(fèi)者亏吝。
      name: Provide
    registry:                 #注冊(cè)中心配置岭埠,用于配置連接注冊(cè)中心相關(guān)信息。
      address: zookeeper://127.0.0.1:2181
    protocol:     #協(xié)議配置蔚鸥,用于配置提供服務(wù)的協(xié)議信息惜论,協(xié)議由提供方指定,消費(fèi)方被動(dòng)接受止喷。
      name: dubbo
      port: 20880
    scan: com.dubboProvide.dubboProvide.service  #服務(wù)暴露與發(fā)現(xiàn)消費(fèi)所在的package
  • 服務(wù)提供者項(xiàng)目結(jié)構(gòu)


    dubboProvide項(xiàng)目結(jié)構(gòu)
  • 服務(wù)接口實(shí)現(xiàn)
    編寫(xiě)Dubbo服務(wù)馆类,只需要添加要發(fā)布的服務(wù)實(shí)現(xiàn)上添加@Service,如下:
package com.dubboProvide.dubboProvide.service.imp;

import com.alibaba.dubbo.config.annotation.Service;
import com.aspire.aplus.service.DemoService;


@Service(version = "1.0.0")
public class DemoServerImp implements DemoService {
    @Override
    public String sayHello(String s) {
        return "你好启盛,"+s+"!";
    }
}

2 服務(wù)消費(fèi)者dubboConsumer:

  • 服務(wù)提供者yml配置文件
server:
  port: 8085

spring:
  dubbo:
    application:            #應(yīng)用配置蹦掐,用于配置當(dāng)前應(yīng)用信息,不管該應(yīng)用是提供者還是消費(fèi)者僵闯。
      name: Consumer
    registry:                 #注冊(cè)中心配置卧抗,用于配置連接注冊(cè)中心相關(guān)信息。
      address: zookeeper://127.0.0.1:2181
    protocol:     #協(xié)議配置鳖粟,用于配置提供服務(wù)的協(xié)議信息社裆,協(xié)議由提供方指定,消費(fèi)方被動(dòng)接受向图。
      name: dubbo
      port: 20880
    scan: com.dubboconsumer.dubboConsumer.service  #服務(wù)暴露與發(fā)現(xiàn)消費(fèi)所在的package
  • 服務(wù)消費(fèi)者項(xiàng)目結(jié)構(gòu)


    dubboConsumer項(xiàng)目結(jié)構(gòu)
  • 服務(wù)消費(fèi)者
    引用Dubbo服務(wù)泳秀,只需要添加要發(fā)布的服務(wù)實(shí)現(xiàn)上添加@Reference,如下:
package com.dubboconsumer.dubboConsumer.service.imp;

import com.alibaba.dubbo.config.annotation.Reference;


import com.aspire.aplus.service.DemoService;
import org.springframework.stereotype.Component;

@Component
public class DubboTestService {

    @Reference(version = "1.0.0")
    public DemoService demoService;

    public String Echo(String s){
        String ret_msg;
        try {
            ret_msg  = demoService.sayHello(s);
        }catch (Exception e){
            e.printStackTrace();
            ret_msg = "出錯(cuò)啦榄攀!";
        }
        return  ret_msg;
    }
}
  • 頁(yè)面接口
    接口去調(diào)用獲取了dubbo服務(wù)的DubboTestService嗜傅,在DubboTestService 再調(diào)用遠(yuǎn)程dubbo服務(wù)demoService的sayHello()方法
package com.dubboconsumer.dubboConsumer.controller;

import com.dubboconsumer.dubboConsumer.service.imp.DubboTestService;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

@RestController
public class DubboTestController {

    @Resource
    private DubboTestService dubboTestService;

    @RequestMapping(value = "hello/{name}",method = RequestMethod.GET)
    public String Hello(@PathVariable String name){
        return dubboTestService.Echo(name);
    }
}

3 驗(yàn)證
將兩個(gè)項(xiàng)目逐一啟動(dòng)(先啟動(dòng)服務(wù)提供者dubboProvide后啟動(dòng)服務(wù)消費(fèi)者dubboConsumer),打開(kāi)瀏覽器檩赢,輸入消費(fèi)者提供的接口:localhost:8085/hello/小咩,結(jié)果如下:



emmm...到這里說(shuō)明最基本的dubbo項(xiàng)目搭建成功啦吕嘀。成功的在dubboConsumer項(xiàng)目中調(diào)用了在dubboProvide提供的業(yè)務(wù)代碼。

上面說(shuō)的老版本dubbo提供的服務(wù)是否能在新版本中使用,經(jīng)過(guò)嘗試偶房,答案是肯定趁曼,過(guò)程踩了個(gè)坑,其中最主要的還是配置文件問(wèn)題棕洋,yml文件寫(xiě)的不符合規(guī)范導(dǎo)致挡闰,可以看下我另一篇文章寫(xiě)到的:yml配置文件讀取出錯(cuò) Exception in thread "main" while scanning for the next token found character '\t(TAB)'

文章到此就結(jié)束了掰盘,寫(xiě)下這篇文章主要是當(dāng)做一個(gè)筆記摄悯,同時(shí)也希望能幫助到一些剛接觸dubbo的同學(xué)。有什么錯(cuò)誤還希望各位能夠幫我指出庆杜,大家共同進(jìn)步射众。^ ^

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市晃财,隨后出現(xiàn)的幾起案子叨橱,更是在濱河造成了極大的恐慌,老刑警劉巖断盛,帶你破解...
    沈念sama閱讀 216,324評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件罗洗,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡钢猛,警方通過(guò)查閱死者的電腦和手機(jī)伙菜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)命迈,“玉大人贩绕,你說(shuō)我怎么就攤上這事『撸” “怎么了淑倾?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,328評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)征椒。 經(jīng)常有香客問(wèn)我娇哆,道長(zhǎng),這世上最難降的妖魔是什么勃救? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,147評(píng)論 1 292
  • 正文 為了忘掉前任碍讨,我火速辦了婚禮,結(jié)果婚禮上蒙秒,老公的妹妹穿的比我還像新娘勃黍。我一直安慰自己,他們只是感情好晕讲,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布覆获。 她就那樣靜靜地躺著榜田,像睡著了一般。 火紅的嫁衣襯著肌膚如雪锻梳。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,115評(píng)論 1 296
  • 那天净捅,我揣著相機(jī)與錄音疑枯,去河邊找鬼。 笑死蛔六,一個(gè)胖子當(dāng)著我的面吹牛荆永,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播国章,決...
    沈念sama閱讀 40,025評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼具钥,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了液兽?” 一聲冷哼從身側(cè)響起骂删,我...
    開(kāi)封第一講書(shū)人閱讀 38,867評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎四啰,沒(méi)想到半個(gè)月后宁玫,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,307評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡柑晒,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評(píng)論 2 332
  • 正文 我和宋清朗相戀三年欧瘪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片匙赞。...
    茶點(diǎn)故事閱讀 39,688評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡佛掖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出涌庭,到底是詐尸還是另有隱情芥被,我是刑警寧澤,帶...
    沈念sama閱讀 35,409評(píng)論 5 343
  • 正文 年R本政府宣布脾猛,位于F島的核電站撕彤,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏猛拴。R本人自食惡果不足惜羹铅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望愉昆。 院中可真熱鬧职员,春花似錦、人聲如沸跛溉。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,657評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至专肪,卻和暖如春刹勃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背嚎尤。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,811評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工荔仁, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人芽死。 一個(gè)月前我還...
    沈念sama閱讀 47,685評(píng)論 2 368
  • 正文 我出身青樓乏梁,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親关贵。 傳聞我的和親對(duì)象是個(gè)殘疾皇子遇骑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)揖曾,斷路器落萎,智...
    卡卡羅2017閱讀 134,651評(píng)論 18 139
  • 想起昨天和Dolores一起看電視,介紹馬德里市中心的隱藏酒吧翩肌。有一家藏身于刮胡子店模暗,前排掛著胡子,后排悠閑地喝著...
    廚房里的xiao閱讀 187評(píng)論 0 0
  • 誰(shuí)的心中沒(méi)有幾個(gè)偶像隶糕,那可是我心靈所有向往,所有的信仰站玄。 很多人會(huì)說(shuō): 當(dāng)我失戀時(shí)枚驻,是她給了我再愛(ài)的勇氣,讓我從泥...
    小白邪閱讀 502評(píng)論 0 0
  • 本集匿名投票榮譽(yù)榜 詩(shī)魁:子雷株旷,作品《22 七絕 茶》 副魁:泓穎再登,作品《4 七絕·采茶》 1 七絕·茶盤(pán) 木隱...
    霙愔閱讀 665評(píng)論 2 5
  • 其實(shí),我是一個(gè)不愛(ài)觀察的人晾剖,總是專(zhuān)注于事的層面锉矢,很少去研究、揣摩人的行為層面齿尽,而且我一直認(rèn)為這樣一直挺好的沽损。 有一...
    令狐飛雪閱讀 184評(píng)論 0 4