当前位置: 首页 > news >正文

Hystrix: 服务降级

cloud是基础,eureka是服务注册和发现,consumer是消费者去消费provider里的东西,消费方式就是Feign和Ribbon,feign  接口消费,ribbon  Rest消费

服务降级发生在客户端,客户端因为请求关闭的服务器,让他访问另一个降级服务

服务熔断发生在服务端,服务器报异常了,就会让请求走第二个服务

先写一个实现类

package com.kuang.springcloud.service;import com.kuang.springcloud.pojo.Dept;
import feign.hystrix.FallbackFactory;
import org.springframework.stereotype.Component;import java.util.List;
//降级
@Component
public class DeptClientServiceFallbackFactory implements FallbackFactory {@Overridepublic DeptClientService create(Throwable throwable) {return new DeptClientService() {@Overridepublic Dept queryById(Long id) {return new Dept().setDeptno(id).setDname("这个Id=>"+id+"没有对应的信息,客户端提供了降级的信息,这个服务现在已经被关闭").setDb_source("没有数据~");}@Overridepublic List<Dept> queryAll() {return null;}@Overridepublic String addDept(Dept dept) {return null;}};}
}

在接口那里加一个注解  feign里

package com.kuang.springcloud.service;import com.kuang.springcloud.pojo.Dept;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;import java.util.List;@Component
@FeignClient(value = "SPRINGCLOUD-PROVIDER-DEPT",fallbackFactory = DeptClientServiceFallbackFactory.class)
public interface DeptClientService {@GetMapping("/dept/get/{id}")Dept queryById(@PathVariable("id") Long id);@GetMapping("/dept/list")List<Dept> queryAll();@PostMapping("/dept/add")String addDept(Dept dept);}

在消费者fegin里的yml文件加上配置 

server:port: 80#开启降级feign.hystrix
feign:hystrix:enabled: true#Eureka 配置
eureka:client:register-with-eureka: false #不向Eureka注册自己service-url:defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

 

然后把服务器关了。

服务降级生效 

 

 就是当服务器在A爆满的时候需要关闭其他的服务器来去跑A的服务,才能支撑,但是别人访问C的时候,你必须采用服务降级,来让他知道服务器关闭了,而不是直接抛个异常给他。

 

http://www.lryc.cn/news/139505.html

相关文章:

  • 高精度运算(加减乘除乘法)
  • Mysql数据库技术知识整理
  • SpringBoot整合Mybatis 简单试用
  • SpringBoot案例-配置文件-yml配置文件
  • Web Components
  • IT运维软件的费用是多少?
  • 基于Three.js的WebXR渲染入门
  • resource doesn‘t have a corresponding Go package.
  • 【微服务】微服务调用原理及服务治理
  • 【在Windows下搭建Tomcat HTTP服务】
  • 前端Vue3框架知识点大全
  • C语言练习2(巩固提升)
  • Vulnhub: DriftingBlues: 1靶机
  • Android项目如何上传Gitee仓库
  • MySQL——基础——联合查询
  • Vue3+Vite 初始化Cesium
  • c++内存地址分配
  • 改进YOLO系列:9.添加S2Attention注意力机制
  • 微服务Feign组件远程调用自定义解码器
  • FairyGUI编辑器自定义菜单扩展插件
  • 若依二次开发
  • 安全(权限)框架Shiro概述及原理
  • java: 无法访问org.springframework.boot.SpringApplication 错误的类文件
  • 改进YOLO系列:7.添加CA注意力机制
  • Linux笔记--Ubuntu设置sftp服务
  • 火山引擎边缘云,助你沉浸式回忆童年
  • Axios跨域请求处理
  • Docker(二) Docker容器
  • 【业务功能篇81】微服务SpringCloud-ElasticSearch-Kibanan-docke安装-入门实战
  • 【UniApp开发小程序】私聊功能uniapp界面实现 (买家、卖家 沟通商品信息)【后端基于若依管理系统开发】