SpringBoot與Dubbo整合的方式詳解
1. 使用默認(rèn)application.properties和注解的方式
導(dǎo)入dubbo-starter,在application.properties配置屬性,使用@Service注解來(lái)暴露服務(wù),使用@Reference來(lái)引用服務(wù)。具體可參考 Dubbo整合SpringBoot,這里截取部分代碼方便理解。
屬性在application.properties中配置

服務(wù)提供方使用@Service注解暴露服務(wù)
部分配置如“timeout”等可以在注解上添加

服務(wù)消費(fèi)方使用@Reference注解來(lái)引用服務(wù)

2. 引入dubbo.xml配置文件
保留dubbo.xml配置文件,導(dǎo)入dubbo-starter,使用@ImportResource導(dǎo)入dubbo的配置文件即可。
如果要實(shí)現(xiàn)暴露服務(wù)中的某個(gè)方法的配置,@Service注解此時(shí)就無(wú)能為力了

xml配置文件中的<dubbo:method />標(biāo)簽可以實(shí)現(xiàn)該功能

這就要求我們引入xml配置文件,方法很簡(jiǎn)單,啟動(dòng)類中通過(guò) @ImportResource 注解引入即可

3. 使用注解API的方式
依舊使用@Service注解來(lái)暴露服務(wù),使用@Reference來(lái)引用服務(wù)。同時(shí)使用注解API的方式來(lái)替代xml配置文件中的標(biāo)簽,將每一個(gè)組件手動(dòng)創(chuàng)建到容器中,讓dubbo來(lái)掃描其他的組件。
注解類的配置主要有三點(diǎn):①注解類加注解@Configuration;②每個(gè)注解項(xiàng)添加@Bean注入到容器中;③準(zhǔn)確使用注解API。
以服務(wù)提供方式的注解類為例:
package com.zang.gmall.config;
import java.util.ArrayList;
import java.util.List;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.alibaba.dubbo.config.ApplicationConfig;
import com.alibaba.dubbo.config.MethodConfig;
import com.alibaba.dubbo.config.RegistryConfig;
import com.alibaba.dubbo.config.ServiceConfig;
import com.zang.gmall.service.UserService;
@Configuration
public class MyDubboConfig {
//<dubbo:application name="boot-user-service-provider"></dubbo:application>
@Bean
public ApplicationConfig applicationConfig() {
ApplicationConfig applicationConfig = new ApplicationConfig();
applicationConfig.setName("user-service-provider");
return applicationConfig;
}
//<dubbo:registry protocol="zookeeper" address="127.0.0.1:2181"></dubbo:registry>
@Bean
public RegistryConfig registryConfig() {
RegistryConfig registryConfig = new RegistryConfig();
registryConfig.setProtocol("zookeeper");
registryConfig.setAddress("127.0.0.1:2181");
return registryConfig;
}
//略
/**
*<dubbo:service interface="com.zang.gmall.service.UserService"
ref="userServiceImpl01" timeout="1000" version="1.0.0">
<dubbo:method name="getUserAddressList" timeout="1000"></dubbo:method>
</dubbo:service>
*/
@Bean
public ServiceConfig<UserService> userServiceConfig(UserService userService){
ServiceConfig<UserService> serviceConfig = new ServiceConfig<>();
serviceConfig.setInterface(UserService.class);
serviceConfig.setRef(userService);
serviceConfig.setVersion("1.0.0");
//配置每一個(gè)method的信息
MethodConfig methodConfig = new MethodConfig();
methodConfig.setName("getUserAddressList");
methodConfig.setTimeout(1000);
//將method的設(shè)置關(guān)聯(lián)到service配置中
List<MethodConfig> methods = new ArrayList<>();
methods.add(methodConfig);
serviceConfig.setMethods(methods);
return serviceConfig;
}
}
使用@DubboComponentScan注解指定dubbo掃描路徑。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JFinal使用ajaxfileupload實(shí)現(xiàn)圖片上傳及預(yù)覽
這篇文章主要為大家詳細(xì)介紹了JFinal使用ajaxfileupload實(shí)現(xiàn)圖片上傳及預(yù)覽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
詳解springboot使用異步注解@Async獲取執(zhí)行結(jié)果的坑
本文主要介紹了springboot使用異步注解@Async獲取執(zhí)行結(jié)果的坑,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
Java操作mongodb增刪改查的基本操作實(shí)戰(zhàn)指南
MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù),由c++語(yǔ)言編寫,旨在為WEB應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲(chǔ)解決方案,下面這篇文章主要給大家介紹了關(guān)于Java操作mongodb增刪改查的基本操作實(shí)戰(zhàn)指南,需要的朋友可以參考下2023-05-05
詳解如何在Spring?Security中自定義權(quán)限表達(dá)式
這篇文章主要和大家詳細(xì)介紹一下如何在Spring?Security中自定義權(quán)限表達(dá)式,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-07-07
JAVA序列化Serializable及Externalizable區(qū)別詳解
這篇文章主要介紹了JAVA序列化Serializable及Externalizable區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07

