zoukankan      html  css  js  c++  java
  • dubbo服务降级和服务容错

    什么是服务降级?

    当服务器压力剧增的情况下,根据实际业务情况及流量,
    对一些服务和页面有策略的不处理或换种简单的方式处理,
    从而释放服务器资源以保证核心交易正常运作或高效运作。
    可以通过服务降级功能临时屏蔽某个出错的非关键服务,并定义降级后的返回策略。
    向注册中心写入动态配置覆盖规则:

    RegistryFactory registryFactory = ExtensionLoader.getExtensionLoader(RegistryFactory.class).getAdaptiveExtension();
    Registry registry = registryFactory.getRegistry(URL.valueOf("zookeeper://10.20.153.10:2181"));
    registry.register(URL.valueOf("override://0.0.0.0/com.foo.BarService?category=configurators&dynamic=false&application=foo&mock=force:return+null"));
    

    mock=force:return+null 表示消费方对该服务的方法调用都直接返回 null 值,不发起远程调用。用来屏蔽不重要服务不可用时对调用方的影响。
    还可以改为 mock=fail:return+null 表示消费方对该服务的方法调用在失败后,再返回 null 值,不抛异常。用来容忍不重要服务不稳定时对调用方的影响。

    集群容错

    在集群调用失败时,Dubbo 提供了多种容错方案,缺省为 failover 重试。
    集群容错模式

    #####Failover Cluster
    失败自动切换,当出现失败,重试其它服务器。通常用于读操作,但重试会带来更长延迟。可通过 retries="2" 来设置重试次数(不含第一次)。
    
    重试次数配置如下:
    <dubbo:service retries="2" />
    或
    <dubbo:reference retries="2" />
    或
    <dubbo:reference>
        <dubbo:method name="findFoo" retries="2" />
    </dubbo:reference>
    
    #####Failfast Cluster
    快速失败,只发起一次调用,失败立即报错。通常用于非幂等性的写操作,比如新增记录。
    
    #####Failsafe Cluster
    失败安全,出现异常时,直接忽略。通常用于写入审计日志等操作。
    
    #####Failback Cluster
    失败自动恢复,后台记录失败请求,定时重发。通常用于消息通知操作。
    
    #####Forking Cluster
    并行调用多个服务器,只要一个成功即返回。通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过 forks="2" 来设置最大并行数。
    
    #####Broadcast Cluster
    广播调用所有提供者,逐个调用,任意一台报错则报错 [2]。通常用于通知所有提供者更新缓存或日志等本地资源信息。
    
    
    集群模式配置
    按照以下示例在服务提供方和消费方配置集群模式
    <dubbo:service cluster="failsafe" />
    或
    <dubbo:reference cluster="failsafe" />
    

    Hystrix

    provider和consumer添加pom依赖
    <dependency>
          <groupId>org.springframework.cloud</groupId>
          <artifactId>
    		spring-cloud-starter-netflix-hystrix
         </artifactId>
    </dependency>
    
    provider开启服务容错
    //@EnableDubbo //开启基于注解的dubbo功能
    //@ImportResource(locations="classpath:provider.xml")
    @EnableDubbo(scanBasePackages="com.atguigu.gmall")
    @EnableHystrix //开启服务容错
    @SpringBootApplication
    public class BootUserServiceProviderApplication {
    
    	public static void main(String[] args) {
    		SpringApplication.run(BootUserServiceProviderApplication.class, args);
    	}
    }
    
    
    provider
    @Service//暴露服务 
    @Component
    public class UserServiceImpl implements UserService {
    
    	@HystrixCommand
    	@Override
    	public List<UserAddress> getUserAddressList(String userId) {
    		// TODO Auto-generated method stub
    		System.out.println("UserServiceImpl..3.....");
    		UserAddress address1 = new UserAddress(1, "北京市昌平区宏福科技园综合楼3层", "1", "李老师", "010-56253825", "Y");
    		UserAddress address2 = new UserAddress(2, "深圳市宝安区西部硅谷大厦B座3层(深圳分校)", "1", "王老师", "010-56253825", "N");
    //		try {
    //			Thread.sleep(2000);
    //		} catch (InterruptedException e) {
    //			e.printStackTrace();
    //		}
    		if(Math.random()>0.5) {
    			throw new RuntimeException();
    		}
    		return Arrays.asList(address1,address2);
    	}
    
    }
    
    
    consumer开启服务容错
    @EnableDubbo
    @EnableHystrix
    @SpringBootApplication
    public class BootOrderServiceConsumerApplication {
    
    	public static void main(String[] args) {
    		SpringApplication.run(BootOrderServiceConsumerApplication.class, args);
    	}
    }
    
    
    consumer
    @Service
    public class OrderServiceImpl implements OrderService {
    
    	//@Autowired
    	@Reference(loadbalance="random",timeout=1000) //dubbo直连
    	UserService userService;
    	
    	@HystrixCommand(fallbackMethod="hello")
    	@Override
    	public List<UserAddress> initOrder(String userId) {
    		// TODO Auto-generated method stub
    		System.out.println("用户id:"+userId);
    		//1、查询用户的收货地址
    		List<UserAddress> addressList = userService.getUserAddressList(userId);
    		return addressList;
    	}
    	
    	
    	public List<UserAddress> hello(String userId) {
    		// TODO Auto-generated method stub
    	
    		return Arrays.asList(new UserAddress(10, "测试地址", "1", "测试", "测试", "Y"));
    	}
    }
    
  • 相关阅读:
    winfrom让窗体在屏幕右下角慢慢向上弹出
    winfrom的StatusStrip控件如何设置控件右对齐
    Winfrom通过Panel拖动无边框窗体
    优秀学习资源汇总
    hexo+github搭建博客跳坑
    博客园主题样式修改
    wxss无法调用本地资源图片
    微信小程序wx:for循环
    Git常用命令总结
    git push解决办法: ! [remote rejected] master -> master (pre-receive hook declined)
  • 原文地址:https://www.cnblogs.com/xidianzxm/p/14392239.html
Copyright © 2011-2022 走看看