内部网站制作,优化手机网站,公司logo设计费用,SEO做得最好的网站1.雪崩问题 级联失败或雪崩问题指的是在微服务架构中#xff0c;由于服务间的相互依赖和调用#xff0c;当一个服务出现故障时#xff0c;会引起调用它的服务也出现故障#xff0c;进而引发整个调用链路的多个服务都出现故障#xff0c;最终导致整个系统崩溃的现象。
产生…1.雪崩问题 级联失败或雪崩问题指的是在微服务架构中由于服务间的相互依赖和调用当一个服务出现故障时会引起调用它的服务也出现故障进而引发整个调用链路的多个服务都出现故障最终导致整个系统崩溃的现象。
产生雪崩原因
服务依赖微服务架构中服务之间通过远程调用相互依赖一旦某个服务出现问题就会影响到依赖它的其他服务。故障传播当一个服务出现故障时如果没有有效的隔离和恢复机制故障会沿着调用链传播导致更多的服务受到影响。资源耗尽如果某个服务占用了过多的系统资源如CPU、内存、网络带宽等会导致其他服务无法获取足够的资源而出现故障。 2.微服务保护
2.1微服务保护方案
微服务保护的方案有很多比如 请求限流 线程隔离 服务熔断 这些方案或多或少都会导致服务的体验上略有下降比如请求限流降低了并发上限线程隔离降低了可用资源数量服务熔断降低了服务的完整度部分服务变的不可用或弱可用。因此这些方案都属于服务降级的方案。但通过这些方案服务的健壮性得到了提升。
2.1.1请求限流 服务故障最重要原因就是并发太高。解决了这个问题就能避免大部分故障。当然接口的并发不是一直很高而是突发的。因此请求限流就是限制或控制接口访问的并发流量避免服务因流量激增而出现故障。 请求限流往往会有一个限流器数量高低起伏的并发请求曲线经过限流器就变的非常平稳。这就像是水电站的大坝起到蓄水的作用可以通过开关控制水流出的大小让下游水流始终维持在一个平稳的量。 2.1.2线程隔离 线程隔离也叫做舱壁模式模拟船舱隔板的防水原理。通过限定每个业务能使用的线程数量而将故障业务隔离避免故障扩散。 当一个业务接口响应时间长而且并发高时就可能耗尽服务器的线程资源导致服务内的其它接口受到影响。所以我们必须把这种影响降低或者缩减影响的范围。 为了避免某个接口故障或压力过大导致整个服务不可用我们可以限定每个接口可以使用的资源范围也就是将其“隔离”起来。 如图所示我们给业务2限定可用线程数量上限为4这样即便服务C而出现故障也不会导致服务器的线程资源被耗尽不会影响到其它接口。
2.1.3服务熔断 线程隔离虽然避免了雪崩问题但故障服务商品服务依然会拖慢购物车服务服务调用方的接口响应速度。而且商品查询的故障依然会导致查询购物车功能出现故障购物车业务也变的不可用了。
所以我们要做两件事情 编写服务降级逻辑就是服务调用失败后的处理逻辑根据业务场景可以抛出异常也可以返回友好提示或默认数据。 异常统计和熔断统计服务提供方的异常比例当比例过高表明该接口会影响到其它服务应该拒绝调用该接口而是直接走降级逻辑。
2.2.Sentinel
2.2.1.介绍和安装
Sentinel是阿里巴巴开源的一款服务保护框架目前已经加入SpringCloudAlibaba中。官方网站
quick-start | Sentinel (sentinelguard.io)https://sentinelguard.io/zh-cn/docs/quick-start.html
Sentinel 的使用可以分为两个部分: 核心库Jar包不依赖任何框架/库能够运行于 Java 8 及以上的版本的运行时环境同时对 Dubbo / Spring Cloud 等框架也有较好的支持。在项目中引入依赖即可实现服务限流、隔离、熔断等功能。 控制台DashboardDashboard 主要负责管理推送规则、监控、管理机器信息等。
为了方便监控微服务我们先把Sentinel的控制台搭建出来。
1下载jar包
下载地址Releases · alibaba/Sentinel (github.com)
2运行
将jar包放在任意非中文、不包含特殊字符的目录下重命名为sentinel-dashboard.jar 然后运行如下命令启动控制台
java -Dserver.port8090 -Dcsp.sentinel.dashboard.serverlocalhost:8090 -Dproject.namesentinel-dashboard -jar sentinel-dashboard.jar
3访问
访问http://localhost:8090页面就可以看到sentinel的控制台了 需要输入账号和密码默认都是sentinel
登录后即可看到控制台默认会监控sentinel-dashboard服务本身 2.2.2.微服务整合
在微服务模块中整合sentinel连接sentinel-dashboard控制台步骤如下
1引入sentinel依赖
!--sentinel--
dependencygroupIdcom.alibaba.cloud/groupId artifactIdspring-cloud-starter-alibaba-sentinel/artifactId
/dependency
2配置控制台
修改application.yaml文件添加下面内容
spring:cloud: sentinel:transport:dashboard: localhost:8090
3访问cart-service的任意端点
重启cart-service然后访问查询购物车接口sentinel的客户端就会将服务访问的信息提交到sentinel-dashboard控制台。并展示出统计信息 点击簇点链路菜单会看到下面的页面 所谓簇点链路就是单机调用链路是一次请求进入服务后经过的每一个被Sentinel监控的资源。默认情况下Sentinel会监控SpringMVC的每一个Endpoint接口。
因此我们看到/carts这个接口路径就是其中一个簇点我们可以对其进行限流、熔断、隔离等保护措施。 默认情况下Sentinel会把路径作为簇点资源的名称无法区分路径相同但请求方式不同的接口查询、删除、修改等都被识别为一个簇点资源这显然是不合适的。 所以我们可以选择打开Sentinel的请求方式前缀把请求方式 请求路径作为簇点资源名
首先在cart-service的application.yml中添加下面的配置
spring:cloud:sentinel:transport:dashboard: localhost:8090http-method-specify: true # 开启请求方式前缀
然后重启服务通过页面访问购物车的相关接口可以看到sentinel控制台的簇点链路发生了变化