dubbo的特性和springCloud的区别

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"?>
<beans......>
    <!--Applicationname-->
    <dubbo:applicationname="hello-world-app"/>
    <!--registryaddress,usedforservicetoregisteritself-->
    <dubbo:registryaddress="multicast://224.5.6.7:1234"/>
    <!--exposethisservicethroughdubboprotocol,throughport20880-->
    <dubbo:protocolname="dubbo"port="20880"/>
    <!--whichserviceinterfacedoweexpose?-->
    <dubbo:serviceinterface="com.xxx.HelloService"ref="helloService"/>
    <!--designateimplementation-->
    <beanid="helloService"class="com.xxx.impl.HelloServiceImpl"/>
</beans>

测试代码:(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"?>
<beans xmlns=......>
    <!--consumerapplicationname-->
    <dubbo:applicationname="consumer-of-helloworld-app"/>
    <!--registryaddress,usedforconsumertodiscoverservices-->
    <dubbo:registryaddress="multicast://224.5.6.7:1234"/>
    <!--whichservicetoconsume?-->
    <dubbo:referenceid="helloService"interface="com.xxx.HelloService"/>
</beans>

客户端测试代码:(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~
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值