欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

dubbo的特性和springCloud的区别

时间:2023-08-05

Dubbo 支持短连接大数据量的服务提供模式,但绝大多数情况下都是使用长连接小数据量的模式提供服务使用的。所以,对于类似于电商等同步调用场景多并且能支撑搭建Dubbo 这套比较复杂环境的成本的产品而言,Dubbo 确实是一个可以考虑的选择。但如果产品业务中由于后台业务逻辑复杂、时间长而导致异步逻辑比较多的话,可能Dubbo 并不合适。同时,对于人手不足的初创产品而言,这么重的架构维护起来也不是很方便。

Spring Cloud由众多子项目组成,如Spring Cloud Config、Spring Cloud Netflix、Spring Cloud Consul 等,提供了搭建分布式系统及微服务常用的工具,如配置管理、服务发现、断路器、智能路由、微代理、控制总线、一次性token、全局锁、选主、分布式会话和集群状态等,满足了构建微服务所需的所有解决方案。比如使用Spring Cloud Config 可以实现统一配置中心,对配置进行统一管理;使用Spring Cloud Netflix 可以实现Netflix 组件的功能 - 服务发现(Eureka)、智能路由(Zuul)、客户端负载均衡(Ribbon)。

dubbo的特性

虽然微服务架构没有公认的技术标准和规范或者草案,但业界已经有一些很有影响力的开源微服务架构框架提供了微服务的关键思路,例如 Dubbo 和 Spring Cloud。
各大互联网公司也有自研的微服务框架,但其模式都与这二者相差不大。

面向接口代理的高性能RPC调用提供高性能的基于代理的远程调用能力,服务以接口为粒度,为开发者屏蔽远程调用底层细节。
智能负载均衡内置多种负载均衡策略,智能感知下游节点健康状况,显著减少调用延迟,提高系统吞吐量。

服务自动注册与发现支持多种注册中心服务,服务实例上下线实时感知。
高度可扩展能力遵循微内核+插件的设计原则,所有核心能力如Protocol、Transport、Serialization被设计为扩展点,平等对待内置实现和第三方实现。
运行期流量调度内置条件、脚本等路由策略,通过配置不同的路由规则,轻松实现灰度发布,同机房优先等功能。

可视化的服务治理与运维提供丰富服务治理、运维工具:随时查询服务元数据、服务健康状态及调用统计,实时下发路由策略、调整配置参数。

微服务的核心

微服务的核心要素在于服务的发现、注册、路由、熔断、降级、分布式配置

Dubbo 总体架构

Provider:暴露服务的提供方,可以通过 jar 或者容器的方式启动服务
Consumer:调用远程服务的服务消费方
Registry:服务注册中心和发现中心
Monitor:统计服务和调用次数,调用时间监控中心
Container:服务运行的容器

Spring Cloud总体架构

Service Provider 暴露服务的提供方
Service Consumer 调用远程服务的服务消费方
EureKa Server 服务注册中心和服务发现中心


Dubbo 演示案例

服务端

定义一个Service Interface:(HelloService.java)

public interface HelloService{ String sayHello(String name);}

 接口的实现类:(HelloServiceImpl.java)

public class HelloServiceImpl implements HelloService{ public String sayHello(String name){ return "Hello" + name; }}

Spring配置:(provider.xml)

<?xmlversion="1.0"encoding="UTF-8"?>

测试代码:(Provider.java)

public class Provider{ public static void main(String[] args){ ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(newString[]{"provider.xml"}); //启动成功,监听端口为20880System.in.read();//按任意键退出 }}

客户端

Spring配置文件:(consumer.xml)

<?xmlversion="1.0"encoding="UTF-8"?>

客户端测试代码:(Consumer.java)

public class Consumer{ public static void main(String[] args){ ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(newString[]{"consumer.xml"}); HelloService helloService = (HelloService)context.getBean("helloService"); //getserviceinvocationproxyStringhello=helloService.sayHello("world"); //doinvoke!System.out.println(hello); //cool,howareyou~ }}

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。