Dubbo学习

一、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://dubbo.apache.org/schema/dubbo http://dubbo.apache.org/schema/dubbo/dubbo.xsd
	http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">

<!-- 1、指定当前服务/应用的名字(同样的服务名字相同,不要和别的服务同名) -->
<dubbo:application name="boot-user-service-provider"></dubbo:application>

<!-- 2、指定注册中心的位置 -->
<!-- <dubbo:registry address="zookeeper://127.0.0.1:2181"></dubbo:registry> -->
<dubbo:registry protocol="zookeeper" address="127.0.0.1:2181"></dubbo:registry>

<!-- 3、指定通信规则(通信协议?通信端口) -->
<dubbo:protocol name="dubbo" port="20882"></dubbo:protocol>

<!-- 4、暴露服务   ref:指向服务的真正的实现对象 -->
<dubbo:service interface="com.atguigu.gmall.service.UserService" 
	ref="userServiceImpl01" timeout="1000" version="1.0.0">
	<dubbo:method name="getUserAddressList" timeout="1000"></dubbo:method>
</dubbo:service>

<!--统一设置服务提供方的规则  -->
<dubbo:provider timeout="1000"></dubbo:provider>


<!-- 服务的实现 -->
<bean id="userServiceImpl01" class="com.atguigu.gmall.service.impl.UserServiceImpl"></bean>


<!-- 连接监控中心 -->
<dubbo:monitor protocol="registry"></dubbo:monitor>

  </beans>

二、consumer.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://dubbo.apache.org/schema/dubbo"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
	http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
	http://dubbo.apache.org/schema/dubbo http://dubbo.apache.org/schema/dubbo/dubbo.xsd
	http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<context:component-scan base-package="com.atguigu.gmall.service.impl"></context:component-scan>


<dubbo:application name="order-service-consumer"></dubbo:application>

<dubbo:registry address="zookeeper://127.0.0.1:2181"></dubbo:registry>

<!--  配置本地存根-->

<!--声明需要调用的远程服务的接口;生成远程服务代理  -->
<!-- 
	1)、精确优先 (方法级优先,接口级次之,全局配置再次之)
	2)、消费者设置优先(如果级别一样,则消费方优先,提供方次之)
-->
<!-- timeout="0" 默认是1000ms-->
<!-- retries="":重试次数,不包含第一次调用,0代表不重试-->
<!-- 幂等(设置重试次数)【查询、删除、修改】、非幂等(不能设置重试次数)【新增】 -->
<dubbo:reference interface="com.atguigu.gmall.service.UserService" 
	id="userService" timeout="5000" retries="3" version="*">
	<!-- <dubbo:method name="getUserAddressList" timeout="1000"></dubbo:method> -->
</dubbo:reference>
	
<!-- 配置当前消费者的统一规则:所有的服务都不检查 -->
<dubbo:consumer check="false" timeout="5000"></dubbo:consumer>

<dubbo:monitor protocol="registry"></dubbo:monitor>
<!-- <dubbo:monitor address="127.0.0.1:7070"></dubbo:monitor> -->

  </beans>

三、SpringBoot与dubbo整合的三种方式:

  方式一
     使用注解的方式
       导入dubbo-starter
       在application.properties配置属性
       使用@Service暴露服务
       使用@Reference引用服务
       使用@EnableDubbo开启注解Dubbo功能
           或者配置包扫描
           dubbo.scan.base-packages=com.atguigu.gmall

       开启注解、包扫描,配置一个即可
       这种方式
       可以在@Service、@Reference注解中配置属性
       属于类的配置,无法精确到方法的配置


  方式二
         使用dubbo的xml配置文件
         导入dubbo-starter
         使用@ImportResource导入dubbo的配置文件即可
         @ImportResource(locations="classpath:provider.xml")
         dubbo的配置文件,之前怎么写,现在还是怎么写,没有特殊要求

         这种方式
         可以做到方法的精确配置


 方式三
         使用注解API的方式
         将每一个组件手动创建到容器中
         让dubbo来扫描其他的组件

四、面试问题

     1、zookeeper宕机与dubbo直连
              
              原因:
                    监控中心宕掉不影响使用,只是丢失部分采样数据
                    数据库宕掉后,注册中心仍能通过缓存提供服务列表查询,但不能注册新服务
                    注册中心对等集群,任意一台宕掉后,将自动切换到另一台
                    注册中心全部宕掉后,服务提供者和服务消费者仍能通过本地缓存通讯
                    服务提供者无状态,任意一台宕掉后,不影响使用
                    服务提供者全部宕掉后,服务消费者应用将无法使用,并无限次重连等待服务提供者恢复

五、dubbo负载均衡配置

          负载均衡策略
              
              Random LoadBalance
                   随机,按权重设置随机概率。
                   在一个截面上碰撞的概率高,但调用量越大分布越均匀,而且按概率使用权重后也比较均匀,有利于动态调整提供者权重。
              RoundRobin LoadBalance
                   轮循,按公约后的权重设置轮循比率。
                   存在慢的提供者累积请求的问题,比如:第二台机器很慢,但没挂,当请求调到第二台时就卡在那,久而久之,所有请求都卡在调到第二台上。

              LeastActive LoadBalance
                   最少活跃调用数,相同活跃数的随机,活跃数指调用前后计数差。
                   使慢的提供者收到更少请求,因为越慢的提供者的调用前后计数差会越大。
              ConsistentHash LoadBalance
                   一致性 Hash,相同参数的请求总是发到同一提供者。
                   当某一台提供者挂时,原本发往该提供者的请求,基于虚拟节点,平摊到其它提供者,不会引起剧烈变动。算法参见:http://en.wikipedia.org/wiki            /Consistent_hashing
                    缺省只对第一个参数 Hash,如果要修改,请配置 <dubbo:parameter key="hash.arguments" value="0,1" />
                    缺省用 160 份虚拟节点,如果要修改,请配置 <dubbo:parameter key="hash.nodes" value="320" />
posted @ 2020-12-07 21:59  jock_javaEE  阅读(122)  评论(0)    收藏  举报