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

幼儿网站模板知名网络推广

幼儿网站模板,知名网络推广,网站建设公司业务,wordpress瀑布流主 #65533;限流是一种预防措施,虽然限流可以尽量避免因高并发而引起的服务故障,但服务还会因为其它原因而故障。而要将这些故障控制在一定范围,避免雪崩,就要靠线程隔离(舱壁模式)和熔断降级手段了。 线程隔离之前讲到…

        限流是一种预防措施,虽然限流可以尽量避免因高并发而引起的服务故障,但服务还会因为其它原因而故障。而要将这些故障控制在一定范围,避免雪崩,就要靠线程隔离(舱壁模式)和熔断降级手段了。

        线程隔离之前讲到过:调用者在调用服务提供者时,给每个调用的请求分配独立线程池,出现故障时,最多消耗这个线程池内资源,避免把调用者的所有资源耗尽。

熔断降级:是在调用方这边加入断路器,统计对服务提供者的调用,如果调用的失败比例过高,则熔断该业务,不允许访问该服务的提供者了。

        可以看到,不管是线程隔离还是熔断降级,都是对客户端(调用方)的保护。需要在调用方 发起远程调用时做线程隔离、或者服务熔断。

        而我们的微服务远程调用都是基于Feign来完成的,因此我们需要将Feign与Sentinel整合,在Feign里面实现线程隔离和服务熔断。

1.FeignClient整合Sentinel

        SpringCloud中,微服务调用都是通过Feign来实现的,因此做客户端保护必须整合Feign和Sentinel。

2.修改配置,开启sentinel功能

        修改OrderService的application.yml文件,开启Feign的Sentinel功能:

feign:sentinel:enabled: true # 开启feign对sentinel的支持

3.编写失败降级逻辑

        业务失败后,不能直接报错,而应该返回用户一个友好提示或者默认结果,这个就是失败降级逻辑。

给FeignClient编写失败后的降级逻辑

①方式一:FallbackClass,无法对远程调用的异常做处理

②方式二:FallbackFactory,可以对远程调用的异常做处理,我们选择这种

这里我们演示方式二的失败降级处理。

步骤一:在feing-api项目中定义类,实现FallbackFactory:

代码:

package cn.itcast.feign.clients.fallback;import cn.itcast.feign.clients.UserClient;
import cn.itcast.feign.pojo.User;
import feign.hystrix.FallbackFactory;
import lombok.extern.slf4j.Slf4j;@Slf4j
public class UserClientFallbackFactory implements FallbackFactory<UserClient> {@Overridepublic UserClient create(Throwable throwable) {return new UserClient() {@Overridepublic User findById(Long id) {log.error("查询用户异常", throwable);return new User();}};}
}

步骤二:在feing-api项目中的DefaultFeignConfiguration类中将UserClientFallbackFactory注册为一个Bean:

@Bean
public UserClientFallbackFactory userClientFallbackFactory(){return new UserClientFallbackFactory();
}

步骤三:在feing-api项目中的UserClient接口中使用UserClientFallbackFactory:

import cn.itcast.feign.clients.fallback.UserClientFallbackFactory;
import cn.itcast.feign.pojo.User;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;@FeignClient(value = "userservice", fallbackFactory = UserClientFallbackFactory.class)
public interface UserClient {@GetMapping("/user/{id}")User findById(@PathVariable("id") Long id);
}

重启后,访问一次订单查询业务,然后查看sentinel控制台,可以看到新的簇点链路:

喜欢的话点个关注吧!

http://www.yayakq.cn/news/163464/

相关文章:

  • 漳州城乡和建设局网站长沙营销型网站设计
  • 长春网站建设q479185700棒公司需要做网站吗
  • 广州网站备案方案做网站必须购买空间吗
  • 南京的网站制作公司最好的网站建设组织
  • 电脑怎么做最新系统下载网站wordpress链接替换
  • 优质的常州网站建设网站建设中的咨询服务
  • 东莞网站关键排名门户网站建设公开情况自查
  • 网站页面设计怎么分析建站手机网站
  • 南京微信网站开发临沂建设网
  • wordpress整站搬家首页空白问题seo培训公司
  • 成都模板网站建设服务泰安网络公司电话
  • 前端网站开发流程图资溪做面包招聘的网站
  • 门户网站开发教程网站建设dyfwzx
  • 公司网站文案推广怎么做网站端口跳转怎么做
  • 网站做中秋专题怎么弄网站固定通栏代码
  • h5制作开发在哪儿seo优化排名易下拉效率
  • 对网站做打包备份处理网络服务是哪个
  • 广州h5网站建设阿里云网站主体变更怎么做
  • 网站建设开发价格高吗国际形势最新消息
  • 网站优化软件推荐关于开展全县中小学校网站群建设的请示报告
  • 网站优化制作wordpress证书在哪里安装包
  • 自己做电影网站可以赚钱吗建一个门户网站要多少钱
  • 怎么用div做网站摄影网站怎么做数据库
  • 移动网站开发工具人人建站
  • 网页设计与网站建设实验报告佛山市住房建设局网站
  • 建设论坛网站自学广州城市建设规划局网站
  • 网站建设属于什么传奇手游网页版
  • 鄂州网站建设网络公司电商网站设计与制作
  • 青岛房地产团购网站建设怎么样做一个自己的网站
  • 做兼职一般去哪个网站做游戏和做网站哪个难