This commit is contained in:
周伟
2022-05-11 19:04:14 +08:00
parent 9440ac7291
commit d9c5ffd627
826 changed files with 0 additions and 481675 deletions

View File

@@ -25,13 +25,7 @@
<meta name="generator" content="Hexo 4.2.0">
</head>
<body>
<div class="book-container">
<div class="book-sidebar">
@@ -55,289 +49,148 @@
<li><a href="/" class="current-tab">首页</a></li>
</ul>
<ul class="uncollapsible">
<li><a href="../">上一级</a></li>
</ul>
<ul class="uncollapsible">
<li>
<a href="/专栏/深入理解 Sentinel/01 开篇词:一次服务雪崩问题排查经历.md.html">01 开篇词:一次服务雪崩问题排查经历.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/02 为什么需要服务降级以及常见的几种降级方式.md.html">02 为什么需要服务降级以及常见的几种降级方式.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/03 为什么选择 SentinelSentinel 与 Hystrix 的对比.md.html">03 为什么选择 SentinelSentinel 与 Hystrix 的对比.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/04 Sentinel 基于滑动窗口的实时指标数据统计.md.html">04 Sentinel 基于滑动窗口的实时指标数据统计.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/05 Sentinel 的一些概念与核心类介绍.md.html">05 Sentinel 的一些概念与核心类介绍.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/06 Sentinel 中的责任链模式与 Sentinel 的整体工作流程.md.html">06 Sentinel 中的责任链模式与 Sentinel 的整体工作流程.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/07 Java SPI 及 SPI 在 Sentinel 中的应用.md.html">07 Java SPI 及 SPI 在 Sentinel 中的应用.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/08 资源指标数据统计的实现全解析(上).md.html">08 资源指标数据统计的实现全解析(上).md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/09 资源指标数据统计的实现全解析(下).md.html">09 资源指标数据统计的实现全解析(下).md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/10 限流降级与流量效果控制器(上).md.html">10 限流降级与流量效果控制器(上).md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/11 限流降级与流量效果控制器(中).md.html">11 限流降级与流量效果控制器(中).md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/12 限流降级与流量效果控制器(下).md.html">12 限流降级与流量效果控制器(下).md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/13 熔断降级与系统自适应限流.md.html">13 熔断降级与系统自适应限流.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/14 黑白名单限流与热点参数限流.md.html">14 黑白名单限流与热点参数限流.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/15 自定义 ProcessorSlot 实现开关降级.md.html">15 自定义 ProcessorSlot 实现开关降级.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/16 Sentinel 动态数据源:规则动态配置.md.html">16 Sentinel 动态数据源:规则动态配置.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/17 Sentinel 主流框架适配.md.html">17 Sentinel 主流框架适配.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/18 Sentinel 集群限流的实现(上).md.html">18 Sentinel 集群限流的实现(上).md.html</a>
</li>
<li>
<a class="current-tab" href="/专栏/深入理解 Sentinel/19 Sentinel 集群限流的实现(下).md.html">19 Sentinel 集群限流的实现(下).md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/20 结束语Sentinel 对应用的性能影响如何?.md.html">20 结束语Sentinel 对应用的性能影响如何?.md.html</a>
</li>
<li>
<a href="/专栏/深入理解 Sentinel/21 番外篇Sentinel 1.8.0 熔断降级新特性解读.md.html">21 番外篇Sentinel 1.8.0 熔断降级新特性解读.md.html</a>
</li>
</ul>
</div>
</div>
<div class="sidebar-toggle" onclick="sidebar_toggle()" onmouseover="add_inner()" onmouseleave="remove_inner()">
<div class="sidebar-toggle-inner"></div>
</div>
<script>
function add_inner() {
@@ -347,9 +200,6 @@
inner.classList.add('show')
}
function remove_inner() {
let inner = document.querySelector('.sidebar-toggle-inner')
@@ -357,9 +207,6 @@
inner.classList.remove('show')
}
function sidebar_toggle() {
let sidebar_toggle = document.querySelector('.sidebar-toggle')
@@ -389,9 +236,6 @@
}
function open_sidebar() {
let sidebar = document.querySelector('.book-sidebar')
@@ -415,13 +259,7 @@ function hide_canvas() {
overlay.classList.remove('show')
}
</script>
<div class="off-canvas-content">
<div class="columns">
@@ -491,9 +329,6 @@ function hide_canvas() {
TokenResult requestParamToken(Long ruleId, int acquireCount, Collection&lt;Object&gt; params);
}
</code></pre>
<ul>
@@ -517,9 +352,6 @@ function hide_canvas() {
private Map&lt;String, String&gt; attachments;
}
</code></pre>
<ul>
@@ -543,9 +375,6 @@ function hide_canvas() {
void stop() throws Exception;
}
</code></pre>
<p>ClusterTokenClient 接口定义启动和停止集群限流客户端的方法,负责维护客户端与服务端的连接。该接口还继承了 TokenService要求实现类必须要实现 requestToken、requestParamToken 方法,向远程服务端请求获取令牌。</p>
@@ -559,9 +388,6 @@ function hide_canvas() {
void stop() throws Exception;
}
</code></pre>
<p>ClusterTokenServer 接口定义启动和停止集群限流客户端的方法,启动能够接收和响应客户端请求的网络通信服务端,根据接收的消费类型处理客户端的请求。</p>
@@ -573,9 +399,6 @@ function hide_canvas() {
extends ClusterTokenServer, TokenService {
}
</code></pre>
<p>EmbeddedClusterTokenServer 接口继承 ClusterTokenServer并继承 TokenService 接口,即整合客户端和服务端的功能,为嵌入式模式提供支持。在嵌入式模式下,如果当前节点是集群限流服务端,那就没有必要发起网络请求。</p>
@@ -627,9 +450,6 @@ function hide_canvas() {
return fallbackToLocalOrPass(rule, context, node, acquireCount, prioritized);
}
</code></pre>
<p>整体流程分为:</p>
@@ -669,9 +489,6 @@ function hide_canvas() {
return null;
}
</code></pre>
<p>ClusterTokenClient 和 EmbeddedClusterTokenServer 都继承 TokenService区别在于ClusterTokenClient 实现类实现 requestToken 方法是向服务端发起请求,而 EmbeddedClusterTokenServer 实现类实现 requestToken 方法不需要发起远程调用,因为自身就是服务端。</p>
@@ -723,9 +540,6 @@ function hide_canvas() {
}
}
</code></pre>
<p>applyTokenResult 方法根据响应状态码决定是否拒绝当前请求:</p>
@@ -759,9 +573,6 @@ function hide_canvas() {
}
}
</code></pre>
<p>fallbackToLocalOrPass 方法根据规则配置的 fallbackToLocalWhenFail 决定是否回退为本地限流,如果 fallbackToLocalWhenFail 配置为 false将会导致客户端在与服务端失联的情况下拒绝所有流量。fallbackToLocalWhenFail 默认值为 true建议不要修改为 false我们应当确保服务的可用性再确保集群限流的准确性。</p>
@@ -799,9 +610,6 @@ function hide_canvas() {
return ClusterFlowChecker.acquireClusterToken(rule, acquireCount, prioritized);
}
</code></pre>
<ul>
@@ -863,9 +671,6 @@ function hide_canvas() {
}
}
</code></pre>
<p>全局 QPS 阈值限流,按名称空间统计 QPS如果需要使用按名称空间 QPS 限流,则可通过如下方式配置阈值。</p>
@@ -875,9 +680,6 @@ function hide_canvas() {
serverFlowConfig.setMaxAllowedQps(1000);
ClusterServerConfigManager.loadFlowConfig(&quot;serviceA&quot;,serverFlowConfig);
</code></pre>
<ul>
@@ -911,9 +713,6 @@ function hide_canvas() {
}
}
</code></pre>
<ul>
@@ -941,9 +740,6 @@ if (prioritized) {
}
return new TokenResult(TokenResultStatus.OK).setRemaining((int) nextRemaining).setWaitInMs(0);
</code></pre>
<p>当 nextRemaining 计算结果大于等于 0 时,执行这部分代码,先记录当前请求被放行,而后响应状态码 OK 给客户端。</p>
@@ -965,9 +761,6 @@ if (occupyAvg &lt;= ClusterServerConfigManager.getMaxOccupyRatio() * globalThres
}
}
</code></pre>
<p>当 nextRemaining 计算结果小于 0 时,如果当前请求具有优先级,则执行这部分逻辑。计算是否可占用下个时间窗口的 pass 指标,如果允许,则告诉客户端,当前请求可放行,但需要等待 waitInMs一个窗口时间大小毫秒之后才可放行。</p>
@@ -987,9 +780,6 @@ if (prioritized) {
}
return blockedResult();
</code></pre>
<p>当 nextRemaining 大于 0且无优先级权限时直接拒绝请求记录当前请求被 Block。</p>
@@ -1047,9 +837,6 @@ return blockedResult();
NAMESPACE_FLOW_ID_MAP.put(namespace, flowIdSet);
}
</code></pre>
<p>实现集群限流需要收集的指标数据有以下几种:</p>
@@ -1071,9 +858,6 @@ return blockedResult();
WAITING
}
</code></pre>
<ul>
@@ -1129,9 +913,6 @@ return blockedResult();
</div>
</div>
</div>
</div>
@@ -1139,9 +920,6 @@ return blockedResult();
</div>
</div>
<a class="off-canvas-overlay" onclick="hide_canvas()"></a>
</div>
@@ -1157,17 +935,11 @@ return blockedResult();
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {
dataLayer.push(arguments);
}
gtag('js', new Date());
gtag('config', 'G-NPSEEVD756');
@@ -1193,9 +965,6 @@ return blockedResult();
setCookie("lastPath", path)
}
function setCookie(cname, cvalue) {
var d = new Date();
@@ -1207,9 +976,6 @@ return blockedResult();
document.cookie = cname + "=" + cvalue + "; " + expires + ";path = /";
}
function getCookie(cname) {
var name = cname + "=";
@@ -1227,12 +993,6 @@ return blockedResult();
return "";
}
</script>
</html>