问题总结

1.hystrix的局部降级逻辑的处理方式

(1)在服务引入Hystrix依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>

2配置容易超时的方法

 超时访问的方法
@HystrixCommand(fallbackMethod = "timeoutHandler",commandProperties = {
        //设置峰值,超过 3 秒,就会调用兜底方法,这个时间也可以由feign控制
        @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds",value = "3000")
})

3启动类也一定加服务熔断
@EnableCircuitBreaker //开启服务熔断

@SpringBootApplication
@EnableDiscoveryClient
@EnableCircuitBreaker //开启服务熔断
public class HystrixPaymentApplication {

    public static void main(String[] args) {
        SpringApplication.run(HystrixPaymentApplication.class,args);
    }
}

提升了耦合度 通过创建一个兜底的方法来进行降级

2.全局降级处理方式

全局服务降级处理在服务消费方上面实现
先定义个一全局的降级方法

public String jiangji(){
    return "这是全局处理降级逻辑的方法.......";
}

使用一个全局降级的注解
@DefaultProperties(defaultFallback=“全局降级的方法”)

在这里插入图片描述
服务降级的话就是

修改Feign客户端接口

@FeignClient(value = "cloud-payment-service",fallback = FallBackService.class)
public interface OrderService {

    @GetMapping("/payment/hystrix/{id}")
    public String paymentInfo_OK(@PathVariable("id")Integer id);

    @GetMapping("/payment/hystrix/timeout/{id}")
    public String paymentInfo_Timeout(@PathVariable("id")Integer id);
}

3.什么是熔断? 熔断有哪几种状态 断路器的工作原理

熔断 当用户访问某个服务的话 达到了他这个最大的访问量之后 ,直接拒绝了用户访问
熔断器的话有三种状态
关闭状态 关闭的话就是 不会对服务器进行熔断
打开状态 请求不再进行调用当前服务,内部设置时钟一般为MTTR(平均故障处理时间)
半开状态 部分请求根据规则调用当前的服务 如果请求成功且符合规则认为当前服务恢复正常 就关闭熔段
服务熔断的话 核心代码如下
在这里插入图片描述

    //服务熔断
    @HystrixCommand(fallbackMethod = "timeoutHandler", commandProperties = {
            @HystrixProperty(name="circuitBreaker.enabled", value="true"),  // 是否开启断路器
            @HystrixProperty(name="circuitBreaker.requestVolumeThreshold", value="10"),  //请求次数
            @HystrixProperty(name="circuitBreaker.sleepWindowInMilliseconds", value="10000"), // 时间窗口期
            @HystrixProperty(name="circuitBreaker.errorThresholdPercentage", value="60"),  // 失败率达到多少后跳闸
            //整体意思:10秒内 10次请求,有6次失败,就跳闸
    })
    public String paymentCircuitBreaker(Integer id){
        //模拟发生异常
        if(id < 0){
            throw new RuntimeException("*****id,不能为负数");
        }
        String serialNumber = IdUtil.simpleUUID();
        return Thread.currentThread().getName() + "\t" + "调用成功,流水号:" + serialNumber;
    }

    public String timeoutHandler(Integer id){
        return "id不能为负数,请重试......";
    }

、如果请求数达到了设置的请求阈值或者请求失败的比例超过了设置的比例,则断路器将从close状态转到open状态,这时所有的请求都会被阻止。
2、sleep一段时间后,下一个请求将被放过,这时断路器处于半开半闭状态,目的是为了验证一下后边的路是否通畅,如果请求失败,则断路器回到open状态;如果成功了则断路器切换到closed状态并且返回响应的结果。

图中下方描述了计数器维护的数据存储结构及工作原理:大概意思是它维护10个桶(bucket),每个桶中记录第i秒请求状态 的数量,当新的一秒请求记录来的时候,计数器会丢掉时间最靠前的桶。

在这里插入图片描述

4.如何开启熔断?

  • 熔断机制的注解是@HystrixCommand;
  • 熔断机制是应对雪崩效应的一种【链路保护机制】,一般存在于服务端;
  • 当扇出链路的某个服务出现故障或响应超时,会进行【服务降级】,进而【熔断该节点的服务调用】,快速返回“错误”的相应信息;
  • Hystrix的熔断存在阈值,缺省是5秒内20次调用失败就会触发;

-一般是某个服务故障或者异常引起,类似显示世界中的“保险丝”,当某个异常条件被触发,直接熔断整个服务,而不是一直等到此服务超时。

5.什么是网关? gateway 的核心概念

网关作为流量的入口,常用功能包括路由转发、权限校验、限流控制等。Spring Cloud gateway作为 Spring Cloud 官方推出的第二代网关框架,取代了 Zuul网关。
在这里插入图片描述
三大核心概念
Route(路由):路由是构建网关的基本模块,它由ID、目标URI,一系列的断言和过滤器组成,如果断言为true则匹配该路由

Predicate(断言):参考的是Java8的java.util.function.Predicate
开发人员可以匹配HTTP请求中的所有内容(例如请求头或请求参数),如果请求与断言相匹配则进行路由

Filter(过滤):指的是Spring框架中GatewayFilyter的实例,使用过滤器,可以在请求被路由前或者之后进行修改

匹配方式就叫断言,实现这个匹配方式就叫filter,对外表现出来就是路由的功能。

6.如何简单使用gateway

搭建一个网管微服务 代号 9527
在这里插入图片描述

引入pom依赖



org.springframework.cloud
spring-cloud-starter-gateway



org.springframework.cloud
spring-cloud-starter-netflix-eureka-client



org.springframework.boot
spring-boot-devtools
runtime
true


org.projectlombok
lombok
true


org.springframework.boot
spring-boot-starter-test
test


com.krisswen.cloud
cloud-api-commons
${project.version}

编写application.yml配置文件

server:
  port: 9527
spring:
  application:
    name: cloud-gateway
  ## GateWay配置
  cloud:
    gateway:
      routes:
      - id: payment_routh  # 路由ID , 没有固定的规则但要求唯一,建议配合服务名
        uri: http://localhost:8001  # 匹配后提供服务的路由地址
        predicates:
        - Path=/payment/**  # 断言,路径相匹配的进行路由

      - id: payment_routh2  # 路由ID , 没有固定的规则但要求唯一,建议配合服务名
        uri: http://localhost:8001  # 匹配后提供服务的路由地址
        predicates:
        - Path=/payment/lb/**  # 断言,路径相匹配的进行路由

# 注册进 eureka Server
eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/
    register-with-eureka: true
    fetch-registry: true

编写启动类

@SpringBootApplication
@EnableEurekaClient
public class GatewayMain9527 {
    public static void main(String[] args) {
        SpringApplication.run(GatewayMain9527.class,args);
    }
}

测试

没使用的时候
在这里插入图片描述

使用网关之后
在这里插入图片描述
这样子就隐藏了业务微服务端口8001,使用网关服务对微服务进行保护

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值