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

苏州网站建设哪家做得好平顶山 网站建设公司

苏州网站建设哪家做得好,平顶山 网站建设公司,做一款简单的app需要多少钱,施工效果图怎么做个人名片: 博主:酒徒ᝰ. 个人简介:沉醉在酒中,借着一股酒劲,去拼搏一个未来。 本篇励志:三人行,必有我师焉。 本项目基于B站黑马程序员Java《SpringCloud微服务技术栈》,SpringCloud…

请添加图片描述
个人名片:

博主:酒徒ᝰ.
个人简介沉醉在酒中,借着一股酒劲,去拼搏一个未来。
本篇励志三人行,必有我师焉。

请添加图片描述
本项目基于B站黑马程序员Java《SpringCloud微服务技术栈》,SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式

【SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 点击观看

目录

  • 三、隔离和降级
    • 1. FeignClient整合Sentinel
    • 2. 线程隔离(舱壁模式)

三、隔离和降级

限流是一种预防措施,虽然限流可以尽量避免因高并发而引起的服务故障,但服务还会因为其它原因而故障。

而要将这些故障控制在一定范围,避免雪崩,就要靠线程隔离(舱壁模式)和熔断降级手段了。

线程隔离:调用者在调用服务提供者时,给每个调用的请求分配独立线程池,出现故障时,最多消耗这个线程池内资源,避免把调用者的所有资源耗尽。
熔断降级:在调用方这边加入断路器,统计对服务提供者的调用,如果调用的失败比例过高,则熔断该业务,不允许访问该服务的提供者了。

可以看到,不管是线程隔离还是熔断降级,都是对客户端(调用方)的保护。需要在调用方 发起远程调用时做线程隔离、或者服务熔断。
而我们的微服务远程调用都是基于Feign来完成的,因此我们需要将Feign与Sentinel整合,在Feign里面实现线程隔离和服务熔断。

1. FeignClient整合Sentinel

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

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

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

feign:sentinel:enabled: true
  1. 编写失败降级逻辑

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

给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 {@Overridepublic Object 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:

@FeignClient(value = "userservice", fallbackFactory = UserClientFallbackFactory.class)
public interface UserClient {@GetMapping("/user/{id}")User findById(@PathVariable("id") Long id);
}

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

在这里插入图片描述
测试:

添加流控规则

在这里插入图片描述

浏览器快速访问,1s超过1次即可。
结果:出现null

在这里插入图片描述

总结

Sentinel支持的雪崩解决方案:

  • 线程隔离(仓壁模式)
  • 降级熔断
    Feign整合Sentinel的步骤:
  • 在application.yml中配置: feign.sentienl.enable=true
  • 给FeignClient编写FallbackFactory并注册为Bean
  • 将FallbackFactory配置到FeignClient

2. 线程隔离(舱壁模式)

  1. 线程隔离的实现方式

线程隔离有两种方式实现:

  • 线程池隔离
  • 信号量隔离(Sentinel默认采用)

线程池隔离:给每个服务调用业务分配一个线程池,利用线程池本身实现隔离效果
信号量隔离:不创建线程池,而是计数器模式,记录业务使用的线程数量,达到信号量上限时,禁止新的请求。

两者的优缺点:
在这里插入图片描述

  1. sentinel的线程隔离

用法说明
在添加限流规则时,可以选择两种阈值类型:

  • QPS:就是每秒的请求数,在快速入门中已经演示过
  • 线程数:是该资源能使用用的tomcat线程数的最大值。也就是通过限制线程数量,实现线程隔离(舱壁模式)。

案例

给 order-service服务中的UserClient的查询用户接口设置流控规则,线程数不能超过 2。然后利用jemeter测试。

1)配置隔离规则

选择feign接口后面的流控按钮:
填写表单:

在这里插入图片描述

2)Jmeter测试

选择《阈值类型-线程数<2》:
一次发生10个请求,有较大概率并发线程数超过2,而超出的请求会走之前定义的失败降级逻辑。

查看运行结果:
在这里插入图片描述

发现虽然结果都是通过了,不过部分请求得到的响应是降级返回的null信息。

总结

  1. 线程隔离的两种手段是?
    信号量隔离
    线程池隔离
  2. 信号量隔离的特点是?
    基于计数器模式,简单,开销小
  3. 线程池隔离的特点是?
    基于线程池模式,有额外开销,但隔离控制更强
http://www.15wanjia.com/news/157897.html

相关文章:

  • 织梦网站怎么做安全措施手机优化软件哪个好
  • 上海响应式网站建设费用易语言做钓鱼网站
  • 长丰住房和建设局网站外贸网站建设注意事项
  • 中山网站建设多少钱最好的电商平台
  • 响应式网站用什么技术做域名注册网
  • 郑州网站建设那家好搭建小程序要钱吗
  • 做自媒体发视频用哪些网站瑞安自适应网站建设
  • wordpress 摘要字数提供邢台网站优化
  • 云梦模板网站优缺点免费建设网站好吗
  • 深圳一元购网站设计公司wordpress 主题中心
  • 福建建设中心网站软文营销网站
  • 密云网站制作案例阿里云服务器做电影网站
  • 优秀个人网站推荐中关村在线手机参数对比报价
  • 自己电脑做服务器上传网站 需要备案吗河南建设安全监督网站
  • 视觉做的比较好的国外网站做企业品牌网站的公司
  • 青海城乡住房和建设厅网站长沙网站开发公
  • 南宁网站建设平台抖音代运营多少钱
  • 汕头站扩建wordpress完整教程 pdf
  • 接单做网站的网站开发任务完成情况
  • 建设网站宽度最好是多少青岛注册公司流程
  • 做网站需要什么专业网站建设毕业设计中期报告
  • 专业做网站报价东莞石龙网站建设莞网站制作
  • 光谷做网站推广公司用自己的手机做网站
  • 国外交易平台有哪些网站优化的内容
  • 做母婴产品哪个网站做的好处wordpress 访问量过大
  • 户县规划建设和住房保障局网站广州的网站建设
  • 岳阳博物馆网站网站建设公司那记号
  • 炒股配资网站建设为什么做网站需要服务器
  • 沃尔玛公司网站建设案例分析现在还有什么推广渠道
  • 网站pc转移动端代码资讯网站开发需求