官网(早先是阿里的,后来提交给Apache维护了)
此依赖无服务端,只需添加在POM文件添加依赖项,并在代码内使用注解即可
dubbo:
protocol:
port: -1 #表示自动寻找端口,从20880开始,自动递增寻找下一个可用端口
name: dubbo
registry:
address: nacos://localhost:8848 #Nacos的地址与端口
consumer:
check: false #表示当项目启动时,不检测消费者的启动状态
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency>
在生产者(Producer)项目中
在Service实现类上,需要加上 @DubboService
在Spring Boot的启动类上,需加上 @EnableDubbo
才能将此项目的服务,注册到Nacos(配置里用的是Nacos)
在消费者(Consumer)项目中
使用 @DubboReference 来注入实现类,实现远程调用Nacos中注册的其他模块的业务逻辑层的接口
因为在Nacos中,注册的都是实现类,所以可以实现类似自动装配的效果
部分公司,可能会要求使用DubboReference装配的,变量名需要使用dubbo开头
类似如下代码
@DubboReference
private IStockService dubboStockService;
此时已经可以实现远程调用了,如需使用分布式事务,需要添加Seata依赖
Dubbo默认已经支持了负载均衡
达内:lzy