zoukankan      html  css  js  c++  java
  • zookeeper,dubbo,dubbo admin

    zookeeper

    1. 分布式协调服务:我们的程序运行在不同的机器上,这些机器可能位于同一个机架,同一个机房又或不同的数据中心。在这样的环境中,我们要实现协调该怎么办?那么这就是分布式协调服务要干的事情。

    2. Zookeeper可以干什么:配置管理,名字服务,分布式锁,集群管理

    3. Zookeeper的配置:clientPort,dataDir,dataLogDir,tickTime,maxClientCnxns ,minSessionTimeout, maxSessionTimeout,autopurge.snapRetainCount,autopurge.purgeInterval()

        配置-myid:在dataDir里会放置一个myid文件,里面就一个数字,用来唯一标识这个服务。这个id是很重要的,一定要保证整个集群中唯一。

        zookeeper会根据这个id来取出server.x上的配置。比如当前id为1,则对应着zoo.cfg里的server.1的配置。

        下面是集群中服务的列表

        server.1=127.0.0.1:20881:30881

        server.2=127.0.0.1:20882:30882

        server.3=127.0.0.1:20883:30883

        在上面的例子中,我把三个zookeeper服务放到同一台机器上。上面的配置中有两个TCP port。后面一个是用于Zookeeper选举用的,而前一个是

        Leader和Follower或Observer交换数据使用的。我们还注意到server.后面的数字。这个就是myid(关于myid是什么下一节会介绍)。

    4. Zookeeper leader选举:

    5. Zookeeper client:create,delete(需要version,乐观锁),exists,setData/getData,getChildren ,sync zookeeper

    Dubbo

    1. Dubbo是什么

        Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,

        才有dubbo这样的分布式服务框架的需求,并且本质上是个服务调用的东东,说白了就是个远程服务调用的分布式框架

        其核心部分包含:  

        1).远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。

        2).集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。

        3).自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

    2. Dubbo能做什么?

        1).透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。

        2).软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。

        3).服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

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

    4. 调用关系说明:

        1).服务容器负责启动,加载,运行服务提供者。

        2).服务提供者在启动时,向注册中心注册自己提供的服务。

        3).服务消费者在启动时,向注册中心订阅自己所需的服务。

        4).注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。

        5).服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。

        6).服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

    5. 连通性,健状性,伸缩性,升级性

    6. dubbo基本配置:

        <dubbo:service/> 服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心。

        eg、<dubbo:service ref="demoService" interface="com.unj.dubbotest.provider.DemoService" />

        <dubbo:reference/> 引用服务配置,用于创建一个远程服务代理,一个引用可以指向多个注册中心。

        eg、<dubbo:reference id="demoService" interface="com.unj.dubbotest.provider.DemoService" />

        <dubbo:protocol/> 协议配置,用于配置提供服务的协议信息,协议由提供方指定,消费方被动接受。

        eg、<dubbo:protocol name="dubbo" port="20880" />

        <dubbo:application/> 应用配置,用于配置当前应用信息,不管该应用是提供者还是消费者。

        eg、<dubbo:application name="xixi_provider" />

        <dubbo:application name="hehe_consumer" />

        <dubbo:module/> 模块配置,用于配置当前模块信息,可选。

        <dubbo:registry/> 注册中心配置,用于配置连接注册中心相关信息。

        eg、<dubbo:registry address="zookeeper://192.168.2.249:2181" />

        <dubbo:monitor/> 监控中心配置,用于配置连接监控中心相关信息,可选。

        <dubbo:provider/> 提供方的缺省值,当ProtocolConfig和ServiceConfig某属性没有配置时,采用此缺省值,可选。

        <dubbo:consumer/> 消费方缺省配置,当ReferenceConfig某属性没有配置时,采用此缺省值,可选。

        <dubbo:method/> 方法配置,用于ServiceConfig和ReferenceConfig指定方法级的配置信息。

        <dubbo:argument/> 用于指定方法参数配置。

    7. 服务调用超时设置,启动时检查 ,订阅,回声测试(测试服务是否可用),延迟连接,令牌验证,日志适配,配置Dubbo缓存文件

    8. 配置文件: dubbo.properties

    dubbo.registry.address=zookeeper://127.0.0.1:2181
    dubbo.admin.root.password=admin
    dubbo.admin.guest.password=guest

       登陆:输入用户名:admin,密码:admin,结果打死都登陆不上。

       这个时候,请仔细看配置文件,文件配置的意思是:

       用户名:root,密码:admin 
       root.password=admin

       用户名:guest,密码:guest 
       guest.password=admin

       转自:http://blog.csdn.net/tengdazhang770960436/article/details/51781480

    dubbo admin

    1. dubbo admin 可以手动刷新。默认情况下,关闭某个接口,admin上一般会正常消失。

    2. 接口的状态分为:正常,没有消费者,没有提供者。以此可以看看注册中心有没有对应的消费(提供)者。

    3. 服务治理中的服务,对应所有注册中心的服务

        服务治理中的应用,应用的名称对应dubbo:application中的name

        服务治理中的机器,对应注册中心对应机器

        服务治理中的提供者,对应注册中心提供服务的接口

        服务治理中的消费者,对应注册中心需要消费的接口  

        服务治理中的路由规则,似乎可以操作更细的规则(白名单?试着操作,无法保存规则)

        服务治理中的动态配置,未知

        服务治理中的访问控制,可以设置黑名单,禁用某些服务器调用指定接口

        服务治理中的权重调节,未知

        服务治理中的负载均衡,未知

        服务治理中的负责人,未知

    4. 可以搜索服务名,应用名,机器IP。注意,需要选择对应标签。

  • 相关阅读:
    北京之行
    csharp进界
    医院OA系统新思考
    茗洋博客
    monkey主要参数详解
    使用python判断Android自动化的渠道包是否全部打完
    手机连接mac电脑无法使用adb命令解决方法
    Python正则表达式指南
    Mac基本命令大全
    Mac之vim普通命令使用
  • 原文地址:https://www.cnblogs.com/Jtianlin/p/6055053.html
Copyright © 2011-2022 走看看