為什么要寫這個(gè)小工具
如果你用過Spring-boot來提供dubbo服務(wù),相信使用中有很多“不爽”的地方。既然使用spring boot,那么能用注解的地方絕不用xml配置,這才是spring-boot-style。開個(gè)玩笑,真正意思是,spring-boot適合一些簡單的、獨(dú)立的服務(wù),一個(gè)大的系統(tǒng)是不適合使用spring-boot來開發(fā)。相反,spring-boot適合那些簡單服務(wù)的搭建。 網(wǎng)上大多數(shù)的方法還是使用xml配置,通過@Import注解來引入xml配置。
怎么使用
對于服務(wù)的消費(fèi)者或提供者,使用dubbo內(nèi)置的注解@Service或@Reference來聲明
在application.properties/yml 中配置dubbo的相關(guān)參數(shù),例如下面就是一個(gè)簡單的消費(fèi)者的配置
1
2
3
4
5
|
dubbo: application: name: lizo-consumer registry: address: zookeeper: //localhost:12181 |
在配置類上使用@EnableDubbo(basePackages = "xxx.xxx.xxx")
來開啟dubbo的自動(dòng)配置
經(jīng)過以上3個(gè)步驟,就可以完成對dubbo的配置,是不是很Spring-bootstyle
dubbo-filter
dubbo有很多擴(kuò)展,其中filter是使用比較多一個(gè)。但是用起來很不方便。如果能像Spring boot定義Spring MVC的filter那樣簡單聲明一個(gè)bean就好了。恩,其實(shí)就是這樣。
1
2
3
4
5
6
7
8
9
10
|
@Bean ProviderFilter providerFilter() { return new ProviderFilter(); } static class ProviderFilter extends AbstractDubboProviderFilterSupport { public Result invoke(Invoker<?> invoker, Invocation invocation) { System.out.println( "ProviderFilter" ); return invoker.invoke(invocation); } } |
更定制化的需求,可以使用Dubbo的@Activate注解來定制化Filter,那么可以這樣
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
@Bean CustomFilter customFilter() { return new CustomFilter(); } @Activate (group = Constants.PROVIDER) static class CustomFilter extends AbstractDubboFilterSupport { public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException { System.out.println( "ProviderFilter2" ); return invoker.invoke(invocation); } public Filter getDefaultExtension() { return this ; } } |
以上所述是小編給大家介紹的spring-boot整合dubbo:Spring-boot-dubbo-starter,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對服務(wù)器之家網(wǎng)站的支持!
原文鏈接:http://www.cnblogs.com/lizo/p/6853474.html