Dubbo入门案例(一)
Dubbo入门案例(二)
Dubbo入门案例(三)
Dubbo入门案例(四)
Dubbo入门案例(五)
Dubbo入门案例(六)
Dubbo入门案例(七)
Dubbo入门案例(八)
什么是服务降级?
当服务器压力剧增的情况下,根据实际业务情况及流量,对一些服务和页面有策略的不处理或换种简单的方式处理,从而释放服务器资源以保证核心交易正常运作或高效运作。
可以通过服务降级功能临时屏蔽某个出错的非关键服务,并定义降级后的返回策略。
说的直白点就是:比如在公司,咱们领导最喜欢干的事情就是,牺牲基层员工的利益,保住核心领导层的利益
8.3.1 第一种方式实现服务降级
data:image/s3,"s3://crabby-images/1832f/1832f322e1dd4908e09bb9b4dd1269ec548d2040" alt=""
mock=force:return+null 表示消费方对该服务的方法调用都直接返回 null 值,不发起远程调用。用来屏蔽不重要服务不可用时对调用方的影响。
还可以改为 mock=fail:return+null 表示消费方对该服务的方法调用在失败后,再返回 null 值,不抛异常。用来容忍不重要服务不稳定时对调用方的影响。
data:image/s3,"s3://crabby-images/1e29b/1e29b9edd1bbb57806c4e07d0d14c52d870d6909" alt=""
启动一个提供者,启动一个消费者
data:image/s3,"s3://crabby-images/1980c/1980c677a7dc597886c8a3f9644be36fd17c095e" alt=""
请求:
data:image/s3,"s3://crabby-images/4f5f9/4f5f96c4fd6b713aa4d76df519a84f38ab24eef0" alt=""
重新开启消费者:
data:image/s3,"s3://crabby-images/1bc99/1bc993e23427fbdb48f9dd1bfe74fda62a3c2317" alt=""
请求:
data:image/s3,"s3://crabby-images/d4317/d4317004fa45d6b98e6b19f72bd5b3a4b3d185de" alt=""
8.3.2 第二种方式实现服务降级
修改工程dubbodemo_consumer,里面的@Reference注解,设置超时时间
package com.maweiqi.controller;
import com.alibaba.dubbo.config.annotation.Reference;
import com.maweiqi.service.HelloService;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
/**
* HelloController
*
* @Author: 马伟奇
* @CreateTime: 2019-07-19
* @Description:
*/
@Controller
@RequestMapping("/demo")
public class HelloController {
@Reference(loadbalance = "random",timeout = 1000)
private HelloService helloService;
@RequestMapping("/hello")
@ResponseBody
public String getName(String name){
//远程调用
String result = helloService.sayHello(name);
System.out.println(result);
return result;
}
}
package com.maweiqi.service.impl;
import com.alibaba.dubbo.config.annotation.Service;
import com.maweiqi.service.HelloService;
import org.springframework.transaction.annotation.Transactional;
/**
* HelloServiceImpl
*
* @Author: 马伟奇
* @CreateTime: 2019-07-18
* @Description:
*/
@Service
@Transactional
public class HelloServiceImpl implements HelloService {
@Override
public String sayHello(String name) {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return "8082 hello " + name;
}
}
data:image/s3,"s3://crabby-images/b3371/b337139fcd26cd5c981d4a4c719c95e2e5b73672" alt=""
网友评论