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

做配资网站多少钱网站建设问一问公司

做配资网站多少钱,网站建设问一问公司,中企动力做的网站被百度屏蔽,番禺网站建设培训班在微服务架构中,服务之间的调用是通过网络进行的,网络的不确定性和依赖服务的不可控性,可能导致某个服务出现异常或性能问题,进而引发整个系统的故障,这被称为 微服务雪崩。为了防止这种情况发生,常用的一些…

在微服务架构中,服务之间的调用是通过网络进行的,网络的不确定性和依赖服务的不可控性,可能导致某个服务出现异常或性能问题,进而引发整个系统的故障,这被称为 微服务雪崩。为了防止这种情况发生,常用的一些保护措施包括超时处理熔断降级限流线程池隔离信号量隔离等。

(1)超时处理:设定超时时间,请求超过一定时间没有响应就返回错误信息,不会无休止等待。

(2)熔断降级:当服务的异常数或异常比例超过了预设的阈值时,熔断器会进入开启状态,暂时中断对该服务的请求,此时走降级方法,能够快速响应,确保系统的基本功能能够继续运行。

(3)限流:限制对服务的请求速率,避免短时间内大量的请求导致系统崩溃。

(4)线程池隔离:给要请求的资源分配一个线程池,通过线程池去控制请求数量

(5)信号量隔离:使用计数器模式,记录请求资源的并发线程数量,达到信号量上限时,禁止新的请求。

信号量隔离适合同步请求,控制并发数,比如:对文件的下载并发数进行控制。

大多数场景都适合使用线程池隔离,对于需要同步操作控制并发数的场景可以使用信号量隔离。

1. 熔断降级的背景

在微服务架构中,服务之间的依赖复杂,任何一个服务的故障都有可能引发连锁反应,导致服务雪崩。为此,引入熔断和降级机制,当某个服务长时间无法响应或者发生错误时,系统可以快速进入降级模式,避免对外提供错误服务。

熔断降级的核心流程包括:

  1. 降级:当远程调用发生异常时,不继续等待,而是直接执行降级逻辑,返回预设的结果。
  2. 熔断:当异常达到某个阈值时,熔断器打开,短时间内不再调用出问题的服务,而是走降级处理,防止继续调用带来更多问题。
  3. 恢复:当经过一段时间后,系统尝试再次调用原服务,如果服务恢复正常,则关闭熔断,恢复正常调用。

2. 熔断降级的具体实现步骤

当远程调用发生异常首先走降级方法,当异常比较或异常数达到阈值将触发熔断,在熔断时间内不再走原来的方法而是走降级方法,可以快速进行响应。

当服务恢复后,熔断时间结束此时会再次尝试请求服务,如果成功请求将关闭熔断,恢复原来的链路。

2.1 在客户端 api 工程定义远程调用接口

在 api 工程中,定义远程调用的接口。这个接口将通过 Feign 进行服务调用。接口通过 @FeignClient 注解进行标注,指定服务名称和请求的路径。

package com.jzo2o.api.user;import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;// 通过 @FeignClient 指定远程服务的名称 user-service
@FeignClient(name = "user-service", path = "/user/api/users")
public interface UserServiceClient {// 定义要调用的远程服务的接口,@GetMapping 表示通过 GET 方法访问@GetMapping("/{id}")User getUserById(@PathVariable("id") Long id);
}

@FeignClient:表示这是一个 Feign 客户端,name 为服务提供者的名称,url 指定服务的地址(可省略,使用服务发现时)。
@GetMapping("/api/users/{id}"):声明需要调用的接口路径。
此接口只定义远程调用的方法,不需要具体实现,Feign 会自动为它生成代理类。

2.2 服务消费者中实现熔断降级

如果在 api 工程定义的远程调用接口中实现统一的熔断降级,则后续所有的消费者都是同一个熔断降级策略,不符合实际工程应用。故在每一个消费者中定义专门远程调用的类实现远程调用、熔断、降级逻辑。

使用@SentinelResource注解定义sentinel监控的资源,@SentinelResource注解的属性具体包括。

value: 用于定义资源的名称,即 Sentinel 会对该资源进行流量控制和熔断降级。

fallback :非限流、熔断等导致的异常执行的降级方法

blockHandler :触发限流、熔断时执行的降级方法

@Component
@Slf4j
public class OrderClient {@Resourceprivate UserServiceClient userServiceClient;// 通过 UserServiceClient 调用远程的用户服务@SentinelResource(value = "getUserInfo", fallback = "detailFallback", blockHandler = "detailBlockHandler")public User getUserInfo(Long userId) {// 调用 api 中定义的远程服务接口return userServiceClient.getUserById(userId);}//执行异常走public User detailFallback(Long id, Throwable throwable) {log.error("非限流、熔断等导致的异常执行的降级方法,id:{},throwable:", id, throwable);return null;}//熔断后的降级逻辑public User detailBlockHandler(Long id, BlockException blockException) {log.error("触发限流、熔断时执行的降级方法,id:{},blockException:", id, blockException);return null;}
}

2.3 服务消费者调用实现熔断降级的方法

@Service
public class OrderService {@Resourceprivate OrderClient orderClient ;// 通过 orderClient 调用远程的用户服务public User getUserInfo(Long userId) {// 调用 OrderClient 的方法return orderClient .getUserInfo(userId);}
}

2.4 在sentinel中配置熔断规则

进入sentinel控制台,左侧点击簇点链路,然后右侧选择getUserInfo,选择+熔断。

为了方便测试熔断效果配置异常数规则,如下:

5秒以内最少请求2次,有1次异常则进行熔断。熔断时长为30秒。

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

相关文章:

  • 电影网站制作网站加入视频
  • 网站建设中的时尚资讯sem是什么牌子
  • 温州网站建设平台建筑人才网招聘信息
  • 网上商城网站开发公司解释seo网站推广
  • 在哪个网做免费网站好做网站不推广
  • 网页建站网站申请grace8WordPress主题
  • 网站里自己怎么做推广中国轻工建设公司网站
  • 上海建设网站服务东莞企业网站建设报价
  • 福建祥盛建设有限公司网站微信小程序开通要钱吗
  • 请问下网站开发怎么弄艺术培训学校系统网站怎么做
  • 汉服网站开发背景请假条模板
  • 龙华网站(建设龙华信科)域名主机 网站建设
  • 灌南县建设局网站高端的食品行业网站开发
  • 湖南网站建设 莫道海宁市住房与建设规划局网站
  • 茶文化建设网站的意义阿里云域名注册官网入口
  • 网站技术建设维护技术论文常见的网页布局有哪些
  • 有什么网站可以做婚庆视频如何推广新产品的方法
  • 网站如何做百度推广门窗专业设计网站
  • 如何评估网站网站建设推广
  • 做电影网站收入网络营销有哪些岗位
  • 做自适应网站加强网站信息建设
  • 网站必须兼容哪些浏览器什么网站可以做产品入驻
  • asp.net 音乐网站开发乐陵seo快速排名
  • 单位网站建设工作总结百度指数总结
  • 做app页面的网站海珠定制型网站建设
  • 上海哪家公司提供专业的网站建设网络培训心得体会教师
  • 网站实现步骤及方法网店设计英文
  • 班级网页设计模板图片阳西网站seo
  • 建设部网站水利设计资质忻州网络公司网站建设
  • 门店广告牌设计seo黑帽技术