spring?boot配置dubbo方式(properties)
dubbo和zookeeper配合使用,具體的它們之間的配置這里不說(shuō)了。
spring boot與dubbo配置有兩種方式
1)spring boot在自己的配置文件application.properties 配置dubbo。(本篇主要說(shuō)這個(gè))
2)spring boot結(jié)合傳統(tǒng)spring dubbo配置文件xml形式。(請(qǐng)看下一篇文章)
本篇主要說(shuō)在自己配置文件里配置dubbo的步驟
1) dubbo接口發(fā)布者配置
1.首先需要引入如下依賴:
<!-- Spring Boot Dubbo 依賴--> <dependency> <groupId>io.dubbo.springboot</groupId> <artifactId>spring-boot-starter-dubbo</artifactId> <version>1.0.0</version> </dependency>
2.在application.properties 文件里配置如下內(nèi)容:
#dubbo提供者的別名,只是個(gè)標(biāo)識(shí) spring.dubbo.application.name=provider #zk地址 spring.dubbo.registry.address=zookeeper://192.168.1.160:2181 #dubbo協(xié)議 spring.dubbo.protocol.name=dubbo #duboo端口號(hào) spring.dubbo.protocol.port=20880 #這是你要發(fā)布到dubbo的接口所在包位置 spring.dubbo.scan=test.spring.dubboService
3.創(chuàng)建一個(gè)要發(fā)布的dubbo接口和其實(shí)現(xiàn)類,具體如下:
package test.spring.dubboService;
public interface TestDubboService {
public String getName(String name);
}package test.spring.dubboService.impl;
import com.alibaba.dubbo.config.annotation.Service;
import test.spring.dubboService.TestDubboService;
@Service
public class TestDubboServiceImpl implements TestDubboService {
@Override
public String getName(String name) {
// TODO Auto-generated method stub
return "姓名:"+name;
}
}
接口上什么都不加,但是其實(shí)現(xiàn)類上要加上一個(gè)注解@Service 注意該注解是com.alibaba.dubbo.config.annotation.Service 如果引入錯(cuò)誤,發(fā)布也不會(huì)成功的。
4.如果發(fā)布的接口需要加入版本號(hào),就可以寫(xiě)為這樣@Service(version="1.0.0.1")
具體的包位置接口請(qǐng)看下圖:

我在前幾篇里說(shuō)過(guò),spring boot默認(rèn)掃描是從啟動(dòng)類開(kāi)始依次向下級(jí)包掃描,如果被調(diào)用方在調(diào)用的時(shí)候還沒(méi)有初始化,就肯定會(huì)找不到的,上圖的接口為什么會(huì)放在實(shí)現(xiàn)類的上層,應(yīng)該就能理解了吧。
到此配置dubbo的發(fā)布方就完成了,直接運(yùn)行啟動(dòng)類,查看dubbo接口的發(fā)布情況。如下:

2) dubbo接口消費(fèi)者配置
1、首先依然要引入spring boot的依賴:
<!-- Spring Boot Dubbo 依賴--> <dependency> <groupId>io.dubbo.springboot</groupId> <artifactId>spring-boot-starter-dubbo</artifactId> <version>1.0.0</version> </dependency>
2.在application.properties 文件里填些dubbo的配置:
spring.dubbo.application.name=consumer-1 #zk地址 spring.dubbo.registry.address=zookeeper://192.168.1.160:2181 #dubbo協(xié)議 spring.dubbo.protocol.name=dubbo #duboo端口號(hào) spring.dubbo.protocol.port=20880 #這是要掃描使用的dubbo接口所在包位置 spring.dubbo.scan=test.spring.dubboService
3.由于消費(fèi)者和發(fā)布者不在同一項(xiàng)目里,上邊的test.spring.dubboService 包里,已發(fā)布接口TestDubboService 也需要復(fù)制一份到消費(fèi)者這邊,并且包結(jié)構(gòu)都必須與發(fā)布的一樣。
注意上邊,這里我說(shuō)的復(fù)制,具體在項(xiàng)目開(kāi)發(fā)里不會(huì)這么干的,比如我們是這樣來(lái)做的。
我們是項(xiàng)目里建了三個(gè)項(xiàng)目(springboot-facade、springboot-rest、springboot-service),springboot-facade里放了接口的結(jié)構(gòu),即service和bean,springboot-rest項(xiàng)目和springboot-service項(xiàng)目分別引用springboot-facade項(xiàng)目,將來(lái)就算別人來(lái)調(diào)用我們的接口,只要引入一下springboot-facade包,配置一下dubbo,就可以了。
當(dāng)然就算webservice那種遠(yuǎn)程調(diào)用,也是需要通過(guò)wsdl去生成service結(jié)構(gòu)在消費(fèi)者這邊。
關(guān)于單項(xiàng)目需要拷貝的話,具體請(qǐng)看下圖,主要是提示一下,復(fù)制的接口在項(xiàng)目所處的路徑必須要與發(fā)布的路徑相同:

4.最后在調(diào)用的地方,我是在TestController 引入的接口,在引入的地方需要加一個(gè)注解,該注解為alibaba的 @Reference ,同理如果想加入版本號(hào),則加上version即可,值要與發(fā)布接口的版本號(hào)對(duì)應(yīng)。
例如:@Reference(version="1.0.0.1"),具體如下:
package test.spring.controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.alibaba.dubbo.config.annotation.Reference;
import test.spring.dubboService.TestDubboService;
@RestController
@RequestMapping("/springboot")
public class TestController {
@Reference
TestDubboService testDubboService;
@RequestMapping(value="abc/akf",method=RequestMethod.GET)
public String abc(String name){
return testDubboService.getName(name);
}
}
5.依次啟動(dòng)dubbo發(fā)布方項(xiàng)目和調(diào)用方項(xiàng)目。
訪問(wèn)以上controller,如果這么運(yùn)行下來(lái),不出意外的話,就會(huì)報(bào)空指針異常,發(fā)布的這個(gè)接口在調(diào)用方調(diào)不到,修改如下即可。
修改后的項(xiàng)目結(jié)構(gòu),如下:

也就是說(shuō),需要把controller的位置放到dubboService下一級(jí),這里就算你在引入的地方加上@Lazy 延遲加載注解也調(diào)用不到,我反正都是調(diào)整包結(jié)構(gòu)解決的空指針異常。
6.再次啟動(dòng)項(xiàng)目,訪問(wèn)controller,就會(huì)訪問(wèn)成功的:

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JVM執(zhí)行引擎和垃圾回收要點(diǎn)總結(jié)
不論是在問(wèn)題現(xiàn)場(chǎng)還是跳槽面試,我們面對(duì)JVM性能問(wèn)題,依舊會(huì)束手無(wú)辭,它需要你對(duì)Java虛擬機(jī)的實(shí)現(xiàn)和優(yōu)化,有極為深刻的理解。所以我在這里整理了一下 JVM的知識(shí)點(diǎn)。今天說(shuō)說(shuō)虛擬機(jī)執(zhí)行引擎和垃圾回收,都是十足的干貨,請(qǐng)各位看官耐心批閱!2021-06-06
Easycode自動(dòng)化springboot的curd
這篇文章主要介紹了Easycode自動(dòng)化springboot的curd,圍繞主題的相關(guān)資料展開(kāi)詳細(xì)內(nèi)容,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望給對(duì)你有所幫助2022-01-01
如何在springboot中實(shí)現(xiàn)頁(yè)面的國(guó)際化
今天帶大家學(xué)習(xí)如何在springboot中實(shí)現(xiàn)頁(yè)面的國(guó)際化,文中有非常詳細(xì)的圖文解說(shuō)及代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下2021-05-05
Java泛型extends及super區(qū)別實(shí)例解析
這篇文章主要介紹了Java泛型extends及super區(qū)別實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
Java實(shí)現(xiàn)Word/Pdf/TXT轉(zhuǎn)html的實(shí)例代碼
本文主要介紹了Java實(shí)現(xiàn)Word/Pdf/TXT轉(zhuǎn)html的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02
Spring Cloud Gateway 緩存區(qū)異常問(wèn)題及解決方案
最近在測(cè)試環(huán)境spring cloud gateway突然出現(xiàn)了異常,接下來(lái)通過(guò)本文給大家介紹Spring Cloud Gateway 緩存區(qū)異常問(wèn)題解決方案,需要的朋友可以參考下2024-06-06
Java調(diào)用JavaScript實(shí)現(xiàn)字符串計(jì)算器代碼示例
這篇文章主要介紹了Java調(diào)用JavaScript實(shí)現(xiàn)字符串計(jì)算器代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。2017-12-12

