美文网首页
dubbo的简单介绍

dubbo的简单介绍

作者: 随心者随心行 | 来源:发表于2018-05-31 22:25 被阅读0次

什么是dubbo

DUBBO是一个分布式服务框架,致力于提供个高性能和透明化的RPC远程服务调用方案,是阿里巴巴SOA服务化治理方案的核心框架。

单一应用框架

  • 当网站流量很小时,只需要一个应用,将所有功能都部署一起,以减少部署节点和成本

  • 此时,用于简化增删改查工作量的,数据访问框架ORM是关键

垂直应用框架

  • 当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率
  • 此时用于加速前端页面开发的Web框架MVC是关键。

分布式服务架构

  • 当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求
  • 此时,用于提高业务服用及整合的分布式服务框架RPC是关键

流动计算架构

  • 当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率
  • 此时,用于提高机器利用率的 资源调度和治理中心 SOA 是关键

Dubbo就是资源调度和治理中心的管理工具

Dubbo就是类似于webservice的关于系统之间通信的框架,并可以统计和管理服务之间的调用情况。包括服务被谁调用了,调用的次数如何,以及服务的使用情况

dubbo 根据Spring的配置

Dubbo采用全Spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spring的Schema扩展进行加载。

  • 单一工程中 spring 的配置 local.xml

<bean id="xxxService"       
    class="com.xxx.XxxServiceImpl" />
   <bean id="xxxAction" 
      class="com.xxx.XxxAction">
   <property name="xxxService" 
      ref="xxxService" />
 </bean>

  • 远程服务:在本地服务的基础上做简单的配置。将上面的local.xml配置拆分成两份,将服务定义部分放在服务提供方remote-provider.xml,将服务引用部分放在服务消费方remote-consumer.xml。
    并在提供方增加暴露服务配置<dubbo:service>,在消费方增加引用服务配置<dubbo:reference>。

服务层发布服务:
<!-- 和本地服务一样实现远程服务 -->
<bean id="xxxService"       
   class="com.xxx.XxxServiceImpl" />
 <!-- 增加暴露远程服务配置 -->
<dubbo:service 
interface="com.xxx.XxxService" ref="xxxService" />

表现层调用服务:
<!-- 增加引用远程服务配置 -->
 <dubbo:reference id="xxxService" 
 interface="com.xxx.XxxService" />
<!-- 和本地服务一样使用远程服务 -->
<bean id="xxxAction" 
 class="com.xxx.XxxAction">
<property name="xxxService" 
  ref="xxxService" />
 </bean>

注册中心

zookeeper的介绍

注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小。使用dubbo-2.3.3以上版本,官方建议使用zookeeper作为注册中心。

Zookeeper是Apacahe Hadoop的子项目,是一个树型的目录服务,支持变更推送,适合作为Dubbo服务的注册中心,工业强度较高(稳定性好),可用于生产环境,并推荐使用。

添加dubbo


  <!-- dubbo相关 -->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>dubbo</artifactId>
        <!-- 排除依赖 -->
        <exclusions>
            <exclusion>
                <groupId>org.springframework</groupId>
                <artifactId>spring</artifactId>
            </exclusion>
            <exclusion>
                <groupId>org.jboss.netty</groupId>
                <artifactId>netty</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.apache.zookeeper</groupId>
        <artifactId>zookeeper</artifactId>
    </dependency>
    <dependency>
        <groupId>com.github.sgroschupf</groupId>
        <artifactId>zkclient</artifactId>
    </dependency>

相关文章

网友评论

      本文标题:dubbo的简单介绍

      本文链接:https://www.haomeiwen.com/subject/owrcsftx.html