zoukankan      html  css  js  c++  java
  • dubbo

    1. Dubbo是什么

    阿里推出的分布式服务框架,是一个基于SOA(面向服务的架构)的基础设施,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。

    优点:
        远程通讯:提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。
        集群容错:提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
        自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

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

    2. 应用场景

    需要用到分布式的场景:

    当网站变大后,不可避免的需要拆分应用进行服务化,以提高开发效率,调优性能,节省关键竞争资源等。 
    当服务越来越多时,服务的URL地址信息就会爆炸式增长,配置管理变得非常困难,F5硬件负载均衡器的单点压力也越来越大。 
    当进一步发展,服务间依赖关系变得错踪复杂,甚至分不清哪个应用要在哪个应用之前启动,架构师都不能完整的描述应用的架构关系。 
    接着,服务的调用量越来越大,服务的容量问题就暴露出来,这个服务需要多少机器支撑?什么时候该加机器?等等……

    3. 架构

    Container: 服务运行容器
    Provider: 暴露服务的服务提供方。
    Consumer: 调用远程服务的服务消费方。
    Registry: 服务注册与发现的注册中心。
    Monitor: 统计服务的调用次调和调用时间的监控中心。

    0. 服务容器负责启动,加载,运行服务提供者。
    1. 服务提供者在启动时,向注册中心注册自己提供的服务。
    2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
    3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
    4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
    5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

    4. dubbo注册中心

    通过将服务统一的管理起来,可有效优化内部应用对服务发布/使用的流程和管理。
    服务注册中心可以通过特定的协议来完成服务对外的统一。
    dubbo提供的注册中心类型:

    • Multicast注册中心
    • Zookeeper注册中心
    • Redis注册中心
    • Simple注册中心

    Zookeeper:
    它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。
    是树型的目录服务的数据存储,能做到集群管理数据 ,这里能很好的作为Dubbo服务的注册中心。

    目标:封装好复杂易出错的关键服务,将简单易用的接口和性能高效、功能稳定的系统提供给用户

    5. RPC

    应用之间交互增多,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心

         

    RPC(remote procedure call protocol):远程过程调用
    RPC是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。
    RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。

    RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。
         a 首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。
         b 在服务器端,进程保持睡眠状态直到调用信息到达为止。当一个调用信息到达,服务器获得进程参 数,计算结果,发送答复信息,然后等待下一个调用信息。
         c 最后,客户端调用进程接收答复信息,获得进程结果,然后调用执行继续进行。

    6. 搭建demo

    步骤:
        安装Zookeeper,启动;
        创建MAVEN项目,构建Dubbo+Zookeeper+Spring实现的简单Demo;
        安装Dubbo-admin,实现监控。

    1、安装Zookeeper:http://blog.csdn.net/tlk20071/article/details/52028945


    2、创建Maven项目,定义接口:

    public interface DemoService {
        List<String> getPermissions(Long id);
    }

    3、创建Maven项目(provider)

    在服务方实现接口:

    /**
     * 服务提供方:提供接口的实现类
     */
    public class DemoServiceImpl implements DemoService {
        public List<String> getPermissions(Long id) {
            List<String> permissions = new ArrayList<String>();
            permissions.add(String.format("Permission_%d", id - 1));
            permissions.add(String.format("Permission_%d", id));
            permissions.add(String.format("Permission_%d", id + 1));
            return permissions;
        }
    }

       

    加载:

    /**
     * 服务提供方
     */
    public class Provider {
            public static void main(String[] args) throws IOException {
                //从类路径下加载配置文件
                ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("provider.xml");
                System.out.println(context.getDisplayName() + ": here");
                context.start();
                System.out.println("服务提供方已经启动,开始提供服务...");
                //按任意键退出
                System.in.read();
            }
    }

     Spring配置声明暴露服务(provider.xml)

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://code.alibabatech.com/schema/dubbo
           http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    
        <!--定义了提供方应用信息,用于计算依赖关系;在 dubbo-admin 或 dubbo-monitor 会显示这个名字,方便辨识-->
        <dubbo:application name="demotest-provider" owner="programmer" organization="dubbox"/>
        <!--使用 zookeeper 注册中心暴露服务,注意要先开启 zookeeper-->
        <dubbo:registry address="zookeeper://localhost:2181"/>
        <!-- 用dubbo协议在20880端口暴露服务 -->
        <dubbo:protocol name="dubbo" port="20880" />
        <!--使用 dubbo 协议实现定义好的 api.DemoService 接口-->
        <dubbo:service interface="com.alibaba.dubbo.demo.DemoService" ref="demoService" protocol="dubbo" />
    
        <!--具体实现该接口的 bean-->
        <bean id="demoService" class="com.alibaba.dubbo.demo.impl.DemoServiceImpl"/>
    </beans>

    4、创建Maven项目(consumer)

         配置spring,引用服务:

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://code.alibabatech.com/schema/dubbo
           http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    
        <dubbo:application name="demotest-consumer" owner="programmer" organization="dubbox"/>
        <!--向 zookeeper 订阅 provider 的地址,由 zookeeper 定时推送-->
        <dubbo:registry address="zookeeper://localhost:2181"/>
        <!--使用 dubbo 协议调用定义好的 api.DemoService接口-->
        <dubbo:reference id="demoService" interface="com.alibaba.dubbo.demo.DemoService" timeout="2000"/>
    
        <dubbo:consumer timeout="3000"/>
        <!--<dubbo:reference id="demoService" interface="com.alibaba.dubbo.demo.DemoService" check="false"/>-->
    </beans>

       

    加载:

    public class Consumer {
        public static void main(String[] args) {
            //测试常规服务
            ClassPathXmlApplicationContext context =
                    new ClassPathXmlApplicationContext("consumer.xml");
            context.start();
            System.out.println("consumer1 start");
            //获取远程服务
            //DemoService demoService = (DemoService) context.getBean("demoService");
            DemoService demoService = context.getBean(DemoService.class);
            System.out.println("consumer1:");
            System.out.println(demoService.getPermissions(1L));
        }
    }
  • 相关阅读:
    关于python的类成员方法允许静态调用的机制
    一个pyqt5动态加载ui+多线程+信号刷新界面的例子
    一个经典的redis队列简单解决方案
    关于连表查询的执行计划
    electron nativefier打包网址 electron-winstaller制作安装包
    MySQL 8.0 字符串比较特殊案例小结
    MySQL SELECT_LEX与subselect 执行 源码阅读笔记
    MySQL 8.0 QueryResolver 源码笔记
    MySQL 8.0 Optimizer 源码笔记
    MySQL Item 源码阅读笔记
  • 原文地址:https://www.cnblogs.com/HarderYao/p/9896273.html
Copyright © 2011-2022 走看看