时间:2023-02-03 07:39:26 | 栏目:JAVA代码 | 点击:次
Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。
Sentinel 具有以下特性:
下面看下sentinel流量控制框架,内容如下所示:
设置日志目录,默认在 $HOME/logs
目录下
//设置metric.log / block.log / sentinel-record.log 等日志目录 System.setProperty("csp.sentinel.log.dir", baseDir + "/csp"); //设置eagleeye-self.log目录 System.setProperty("EAGLEEYE.LOG.PATH", baseDir + "/eagleeye");
metric.log
是记录统计的qps信息,例如passQps、blockQps、successQps、exceptionQps,rt等等,一秒统计一次,可以通过com.alibaba.csp.sentinel.node.metric.MetricNode#fromFatString(String line)
将记录转为MetricNode
实体类对象。sentinel-block.log
是限流/熔断时候统计的blockqps信息,一秒统计一次。细节部分,避免踩坑,下面是梳理好的逻辑,所谓一线大厂,源码里面写的是真的乱啊。。。