上海新建设建筑设计有限公司网站,网站建设教学课件,页面设计怎么样,图片在线编辑器前言#xff1a; 微服务之间通信框架dubbo#xff0c;使用netty #xff08;NIO 模型#xff09;完成RPC 接口调用#xff1b;
1 dubbo 介绍#xff1a;
Apache Dubbo 是一款 RPC 服务开发框架#xff0c;用于解决微服务架构下的服务治理与通信问题#xff0c;官方提…前言 微服务之间通信框架dubbo使用netty NIO 模型完成RPC 接口调用
1 dubbo 介绍
Apache Dubbo 是一款 RPC 服务开发框架用于解决微服务架构下的服务治理与通信问题官方提供了 Java、Golang 等多语言 SDK 实现。使用 Dubbo 开发的微服务原生具备相互之间的远程地址发现与通信能力 利用 Dubbo 提供的丰富服务治理特性可以实现诸如服务发现、负载均衡、流量调度等服务治理诉求。Dubbo 被设计为高度可扩展用户可以方便的实现流量拦截、选址的各种定制逻辑。 在云原生时代Dubbo 相继衍生出了 Dubbo3、Proxyless Mesh 等架构与解决方案在易用性、超大规模微服务实践、云原生基础设施适配、安全性等几大方向上进行了全面升级。
2 spring-cloud 集成dubbo
2.1 抽取要对外发布的接口到api 模块中
public interface DubboTestService {// 暴露dubbo 服务String test();
}2.2 服务提供者 1增加依赖pom
dependencygroupIdcom.alibaba.cloud/groupIdartifactIdspring-cloud-starter-dubbo/artifactId
/dependency2实现要暴露的接口
// dubbo 服务暴露标识实现要暴露的方法
DubboService
public class DubboTestServiceImpl implements DubboTestService {Overridepublic String test() {return hello;}
}3启动类增加暴露接口的扫描路径
DubboComponentScan(basePackages org.lgx.bluegrass.bluegrasses.module.subscribe.service)4bootstrap.yml 增加dubbo 服务协议配置
dubbo:protocol:name: dubboport: 20881registry:address: spring-cloud://localhost #使用SpringCloud中的注册中心2.3 服务消费端 1增加依赖pom
dependencygroupIdcom.alibaba.cloud/groupIdartifactIdspring-cloud-starter-dubbo/artifactId
/dependency消费接口
import org.apache.dubbo.config.annotation.DubboReference;
import org.lgx.bluegrass.api.service.DubboTestService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
RestController
public class DubboRpcController {// dubbo 服务调用DubboReferenceprivate DubboTestService dubboTestService;RequestMapping(value /dubbo-test, method RequestMethod.GET)public String index() {return dubboTestService.test();}}3bootstrap.yml 增加dubbo 服务协议配置
dubbo:registry:address: spring-cloud://localhost #使用cloud的注册中心consumer:check: false #dubbo默认有启动检查retries: 0 #dubbo内置的重试机制2.4 测试
3 dubbo 和feign 关系
两者底层都是通过tcp 完成通信feign 是应用层dubbo 是传输层feign 每次通信都进行连接建立dubbo 会建立长连接dubbo 的性能要优于feign
4 参考
1Dubbo x Spring Boot 开发微服务应用 2配置项参考手册;