dubbo学习(四)配置dubbo 注解方式配置
provider
service注解暴露服務
@Service public class AnnotationServiceImpl implements AnnotationService {@Overridepublic String sayHello(String name) {return "annotation: hello, " + name;} }PS:@Service注解很容易用錯,目前有兩個包有@Service注解:
com.alibaba.dubbo.config.annotation.Service:用于標注對外暴露的dubbo接口實現類。
org.springframework.stereotype.Service:用于標注根據業務塊分離的Service的實現類,對應的是業務層(如一個dubbo方法可能調用多個業務塊的service,這些service的實現類就用Spring的注解)。
增加應用共享配置
# 配置生產者連接的注冊中心的信息 # dubbo-provider.properties dubbo.application.name=annotation-provider dubbo.registry.address=zookeeper://127.0.0.1:2181 dubbo.protocol.name=dubbo dubbo.protocol.port=20880指定Spring掃描路徑
@Configuration @EnableDubbo(scanBasePackages = "org.apache.dubbo.samples.simple.annotation.impl") @PropertySource("classpath:/spring/dubbo-provider.properties") static public class ProviderConfiguration {}?
PS:@Configuration用于定義配置類,可替換xml配置文件,被注解的類內部包含有一個或多個被@Bean注解的方法,
這些方法將會被AnnotationConfigApplicationContext或AnnotationConfigWebApplicationContext類進行掃描,并用
于構建bean定義,初始化Spring容器。
?
? @EnableDubbo開啟注解Dubbo功能 ,scanBasePackages屬性配置包掃描的路徑,用于掃描并注冊bean
?
@PropertySource注解的目的是加載指定的屬性文件,將properties配置文件中的值存儲到Spring的?Environment中,Environment接口提供方法去讀取配置文件中的值。
?
consumer
Reference注解引用服務
@Component("annotationAction") public class AnnotationAction {@Referenceprivate AnnotationService annotationService;public String doSayHello(String name) {return annotationService.sayHello(name);} }?
PS:@Component(把普通pojo實例化到spring容器中,相當于配置文件中的 <bean id="" class=""/>) 泛指各種組件,
就是說當我們的類不屬于各種歸類的時候(不屬于@Controller、@Services等的時候),我們就可以使用@Component來標注這個類。
例:<context:component-scan base-package=”com.*”>?
上面的這個例子是引入Component組件的例子,其中base-package表示為需要掃描的所有子包。?
?
? @Reference與@Autowired、@Resource注解功能類似,用于依賴注入,一般注入的是分布式的遠程服務的對象,需要dubbo配置使用
?
增加應用共享配置
# 配置消費者連接的注冊中心的信息 # dubbo-consumer.properties dubbo.application.name=annotation-consumer dubbo.registry.address=zookeeper://127.0.0.1:2181 dubbo.consumer.timeout=3000指定Spring掃描路徑
@Configuration @EnableDubbo(scanBasePackages = "org.apache.dubbo.samples.simple.annotation.action") @PropertySource("classpath:/spring/dubbo-consumer.properties") @ComponentScan(value = {"org.apache.dubbo.samples.simple.annotation.action"}) static public class ConsumerConfiguration {}?
PS:@ComponentScan主要就是定義掃描的路徑從中找出標識了需要裝配的類自動裝配到spring的bean容器中。
?
?
調用服務
public static void main(String[] args) throws Exception {AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(ConsumerConfiguration.class);context.start();final AnnotationAction annotationAction = (AnnotationAction) context.getBean("annotationAction");String hello = annotationAction.doSayHello("world"); }?
?
轉載于:https://www.cnblogs.com/riches/p/11195184.html
總結
以上是生活随笔為你收集整理的dubbo学习(四)配置dubbo 注解方式配置的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第1节 kafka消息队列:7、kafk
- 下一篇: 生成Apk遇到的问题