SFB(Stochastic Fair Blue)是一个FIFO类型的队列算法,基于类似于BLUE算法的记账机制,来标识非响应性质的流,并且限制其速率(这类流不处理ECN或者丢包事件)。SFB的记账系统由L*N个桶(bin)组成,其中L表示级别,N表示每个级别的桶的数量。Linux内核中使用8个级别,每个级别16个桶用于记账。

 37 #define SFB_BUCKET_SHIFT 438 #define SFB_NUMBUCKETS  (1 << SFB_BUCKET_SHIFT) /* N bins per Level */39 #define SFB_BUCKET_MASK (SFB_NUMBUCKETS - 1)40 #define SFB_LEVELS  (32 / SFB_BUCKET_SHIFT) /* L */

另外,SFB维护着L数量的独立哈希函数,对应于记账系统中的L个级别,每个哈希函数将数据流映射到其对应级别的某个桶中,这些桶用于记录匹配流的队列占用情况。SFB的每个桶维持着一个类似于BLUE算法的marking/dropping probability (Pm)值,每次桶被占用的使用更新此值。例如,在某个报文到达队列后,根据L个级别的相应哈希函数,将其哈希到每个级别的N个桶中的一个。如果摸个映射到某个桶的报文数量超过一定的阈值,此桶的Pm值将增加;如果桶中的报文数据降为零,减小Pm值。

如下为使用伪代码描述的以上介绍的SFB记账系统算法。

B[l][n]: L x N array of bins (L levels, N bins per level)
enque()Calculate hash function values h0, h1, ..., hL-1;Update bins at each levelfor i = 0 to L - 1if (B[i][hi].qlen > bin size)B[i][hi].pm += delta;Drop packet;else if (B[i][hi].qlen == 0)B[i][hi].pm -= delta;pmin = min(B[0][h0].pm .. B[L][hL].pm);if (pmin == 1)ratelimit()elseMark/drop with probability pmin;

对于某个非响应的流,其会很快将SFB记账系统中L个级别的每个级别对应的哈希桶的Pm值拉高为1。对于响应式的流,其有可能与非响应流共同使用某几个级别中的桶,但是,只要非响应流的数量不是远远大于桶的数量,响应式流就有很大可能哈希到至少一个没有被非响应式占用的桶,以上算法可见,流的最小Pm值为每个级别中其对应的哈希桶的Pm值中的最小值,所有,响应式流将保持一个正常的Pm值。报文的(ECN)标记依据最小Pm值实现,如果Pmin为1,SFB认为此流为一个非响应式流,将对其进行限速(penalty_rate)。

如下图所示,一个非响应式流将它映射到的所有哈希桶的Pm(marking probablilities)值都增加到了1,而图中的TCP流(响应式流)在级别0与非响应式流哈希到了同一个桶中,但是在其它级别中二者完全在不同的桶中,所以,TCP流的最小Pmin没有受到影响,其值为0.2。另一方面,由于非响应式流的最小Pm为1,其被标识为非响应流,并且进行限速处理。

在这里插入图片描述

基于以上SFB的介绍, 响应式流也有可能也非响应式流共用所有相同的哈希桶,导致其被误判定为非响应流。对于一个L级别,每个级别B个桶的SFB,如果非响应式流的数量为M,那么,响应式流被误判的可能p由以下公式给出:

p=[1(11B)M]L p = \left [ 1 - \left ( 1-\frac{1}{B} \right )^{M} \right ]^{L}

对于Linux内核的8级别、每级别16个桶的情况,带入以上公式可得:

p=[1(1116)M]8 p = \left [ 1 - \left ( 1-\frac{1}{16} \right )^{M} \right ]^{8}

举例来说,对于数量为10(M=10)的非响应式流的系统,响应式流被误判的可能性为0.2%。为解决此问题,SFB每隔一段时间执行重哈希操作,将误判限制在一定的时间内。

以下为tc命令中sfb的帮助信息和配置命令。

$ tc qdisc add sfb help
What is "help"?
Usage: ... sfb [ rehash SECS ] [ db SECS ][ limit PACKETS ] [ max PACKETS ] [ target PACKETS ][ increment FLOAT ] [ decrement FLOAT ][ penalty_rate PPS ] [ penalty_burst PACKETS ]
$ 
$ sudo tc qdisc add dev ens38 handle 1: root sfb rehash 600000 db 60000 limit 1000 max 25 target 20 increment 0.00050 decrement 0.00005 penalty_rate 10 penalty_burst 20
$ 
$ tc qdisc show dev ens38
qdisc sfb 1: root refcnt 2 limit 1000 max 25 target 20increment 0.00050 decrement 0.00005 penalty rate 10 burst 20 (600000ms 60000ms)
$ 

以上配置的实际上都是SFB的默认参数,参见以下的sfb_default_ops结构的成员赋值。limit参数为零的话,将在初始化过程中重新赋值为网络设备的发送队列长度(例如:1000)。

static const struct tc_sfb_qopt sfb_default_ops = {.rehash_interval = 600 * MSEC_PER_SEC,.warmup_time = 60 * MSEC_PER_SEC,.limit = 0,.max = 25,.bin_size = 20,.increment = (SFB_MAX_PROB + 500) / 1000, /* 0.1 % */.decrement = (SFB_MAX_PROB + 3000) / 6000,.penalty_rate = 10,.penalty_burst = 20,
};  

以下命令用于显示sfb的相关运行信息:

$ tc -s qdisc show dev ens38 
qdisc sfb 1: root refcnt 2 limit 1000 max 25 target 20increment 0.00050 decrement 0.00005 penalty rate 10 burst 20 (600ms 60ms)Sent 1032 bytes 12 pkt (dropped 0, overlimits 0 requeues 0) backlog 0b 0p requeues 0 earlydrop 0 penaltydrop 0 bucketdrop 0 queuedrop 0 childdrop 0 marked 0maxqlen 0 maxprob 0.00000 avgprob 0.00000 

SFB入队列

如下SFB入队列函数sfb_enqueue,当队列长度超过或者等于限制值limit时,丢弃报文。

static int sfb_enqueue(struct sk_buff *skb, struct Qdisc *sch, struct sk_buff **to_free)
{struct sfb_sched_data *q = qdisc_priv(sch);struct Qdisc *child = q->qdisc;struct tcf_proto *fl;u32 p_min = ~0;u32 minqlen = ~0;u32 r, sfbhash;u32 slot = q->slot;int ret = NET_XMIT_SUCCESS | __NET_XMIT_BYPASS;if (unlikely(sch->q.qlen >= q->limit)) {qdisc_qstats_overlimit(sch);q->stats.queuedrop++;goto drop;}

如果重新进行哈希操作的时间间隔大于零,判断是否时间已到,成立的话进行扰数的更新和slot的切换,参见函数sfb_swap_slot,并且更新重哈希时间戳。否则,如果到了双缓存的预热时间,开启双缓存double_buffering预热,变量warmup_time定义了在重哈希之前的多长时间为预热时间。

    if (q->rehash_interval > 0) {unsigned long limit = q->rehash_time + q->rehash_interval;if (unlikely(time_after(jiffies, limit))) {sfb_swap_slot(q);q->rehash_time = jiffies;} else if (unlikely(!q->double_buffering && q->warmup_time > 0 &&time_after(jiffies, limit - q->warmup_time))) {q->double_buffering = true;}}

SFB可使用tc配置的外部classifier分类器,也可使用内部的哈希计算值(默认情况),两种情况都要增加扰数(perturbation-每个slot有不同的扰数)。

    fl = rcu_dereference_bh(q->filter_list);if (fl) {u32 salt;/* If using external classifiers, get result and record it. */if (!sfb_classify(skb, fl, &ret, &salt))goto other_drop;sfbhash = jhash_1word(salt, q->bins[slot].perturbation);} else {sfbhash = skb_get_hash_perturb(skb, q->bins[slot].perturbation);}if (!sfbhash)sfbhash = 1;sfb_skb_cb(skb)->hashes[slot] = sfbhash;

得到的哈希值为32bit,内核的SFB实现使用8个级别(SFB_LEVELS),每个级别16个桶(SFB_BUCKET_SHIFT=4),这样每4位的哈希值可覆盖一个级别内所有的桶。如果哈希桶的队列长度为零,降低Pm值。反之,如果队列长度大于设定的桶大小(bin_size,这里为20),增加Pm的值。

另外,在循环过程中,记录下最小的队列长度,以及Pm的最小值(p_min)。

    for (i = 0; i < SFB_LEVELS; i++) {u32 hash = sfbhash & SFB_BUCKET_MASK;struct sfb_bucket *b = &q->bins[slot].bins[i][hash];sfbhash >>= SFB_BUCKET_SHIFT;if (b->qlen == 0)decrement_prob(b, q);else if (b->qlen >= q->bin_size)increment_prob(b, q);if (minqlen > b->qlen)minqlen = b->qlen;if (p_min > b->p_mark)p_min = b->p_mark;}

如果最小队列长度(minqlen)已经大于设定的最大值,将报文丢弃。

    slot ^= 1;sfb_skb_cb(skb)->hashes[slot] = 0;if (unlikely(minqlen >= q->max)) {qdisc_qstats_overlimit(sch);q->stats.bucketdrop++;goto drop;}

以上的slot与1的异或操作,已经反转了slot的值。在Pmin的值大于等于SFB_MAX_PROB的情况下,如果启用了double_buffering预热功能,依据报文的哈希结果,对预备slot的哈希桶进行类似的操作。最后,调整到enqueue执行,将报文添加到队列中。

    if (unlikely(p_min >= SFB_MAX_PROB)) {/* Inelastic flow */if (q->double_buffering) {sfbhash = skb_get_hash_perturb(skb, q->bins[slot].perturbation);if (!sfbhash)sfbhash = 1;sfb_skb_cb(skb)->hashes[slot] = sfbhash;for (i = 0; i < SFB_LEVELS; i++) {u32 hash = sfbhash & SFB_BUCKET_MASK;struct sfb_bucket *b = &q->bins[slot].bins[i][hash];sfbhash >>= SFB_BUCKET_SHIFT;if (b->qlen == 0)decrement_prob(b, q);else if (b->qlen >= q->bin_size)increment_prob(b, q);}}if (sfb_rate_limit(skb, q)) {qdisc_qstats_overlimit(sch);q->stats.penaltydrop++;goto drop;}goto enqueue;}

如果以上条件不成立,进行随机报文丢弃(RED/ECN)处理。即Pmin的值小于SFB_MAX_PROB,取一个随机值,如果此随机值(r)小于Pmin,并且报文支持ECN,设置marked标记,否则,丢弃报文。但是,在此之前,先判断一下Pmin是否过大,如果大于SFB_MAX_PROB的一半,并且随机值r的一半小于Pmin超出(SFB_MAX_PROB / 2)的值,直接丢弃报文,不进行ECN标记判断。

    r = prandom_u32() & SFB_MAX_PROB;if (unlikely(r < p_min)) {if (unlikely(p_min > SFB_MAX_PROB / 2)) {/* If we're marking that many packets, then either* this flow is unresponsive, or we're badly congested.* In either case, we want to start dropping packets.*/if (r < (p_min - SFB_MAX_PROB / 2) * 2) {q->stats.earlydrop++;goto drop;}}if (INET_ECN_set_ce(skb)) {q->stats.marked++;} else {q->stats.earlydrop++;goto drop;}}

以下为qdisc的入队列函数,成功入队列之后,使用函数increment_qlen增加SFB哈希桶中相应的队列长度。

enqueue:ret = qdisc_enqueue(skb, child, to_free);if (likely(ret == NET_XMIT_SUCCESS)) {qdisc_qstats_backlog_inc(sch, skb);sch->q.qlen++;increment_qlen(skb, q);} else if (net_xmit_drop_count(ret)) {q->stats.childdrop++;qdisc_qstats_drop(sch);}

SFB出队列

SFB的出队列处理相对来说比较简单,调用SFB的函数decrement_qlen减少哈希桶中对于bin的队列长度。

static struct sk_buff *sfb_dequeue(struct Qdisc *sch)
{struct sfb_sched_data *q = qdisc_priv(sch);struct Qdisc *child = q->qdisc;struct sk_buff *skb;skb = child->dequeue(q->qdisc);if (skb) {qdisc_bstats_update(sch, skb);qdisc_qstats_backlog_dec(sch, skb);sch->q.qlen--;decrement_qlen(skb, q);}return skb;
}

SFB虚拟队列长度

在成功执行qdisc_enqueue之后,调用increment_qlen增加队列长度。这里分别对两个slot:0和1,分别执行增加操作。对于队列长度的递减decrement_qlen函数,原理相同,分别递减slot0和1中相应的哈希桶队列长度。

static void increment_qlen(const struct sk_buff *skb, struct sfb_sched_data *q)
{u32 sfbhash;sfbhash = sfb_hash(skb, 0);if (sfbhash)increment_one_qlen(sfbhash, 0, q);sfbhash = sfb_hash(skb, 1);if (sfbhash)increment_one_qlen(sfbhash, 1, q);
}

遍历指定slot中,每个级别(SFB_LEVELS)中哈希对应的桶,如果其队列长度小于0xFFFF,将其递增。队列的递减函数decrement_one_qlen,原理与此相同。

static void increment_one_qlen(u32 sfbhash, u32 slot, struct sfb_sched_data *q)
{int i;struct sfb_bucket *b = &q->bins[slot].bins[0][0];for (i = 0; i < SFB_LEVELS; i++) {u32 hash = sfbhash & SFB_BUCKET_MASK;sfbhash >>= SFB_BUCKET_SHIFT;if (b[hash].qlen < 0xFFFF)b[hash].qlen++;b += SFB_NUMBUCKETS; /* next level */}
}

标记概率Pm计算

当队列长度等于零时,减低Pm的值,如下函数decrement_prob。递减的步长decrement可通过TC命令设置,默认为:(SFB_MAX_PROB + 3000) / 6000。

static void decrement_prob(struct sfb_bucket *b, struct sfb_sched_data *q)
{b->p_mark = prob_minus(b->p_mark, q->decrement);
}

当队列长度大于等于bin_size时(以上TC命令设置为20,其也是默认值),增加Pm值。递增的步长increment可通过TC命令设置,默认为:(SFB_MAX_PROB + 500) / 1000。

static void increment_prob(struct sfb_bucket *b, struct sfb_sched_data *q)
{b->p_mark = prob_plus(b->p_mark, q->increment);
}

Pm值使用Q0.16格式表示,即没有整数部分,小数部分由16bit表示。默认情况下,increment的值等于:(65535 + 500)/1000 = 66.035,除以SFB_MAX_PROB的话,相当于0.001007。decrement的默认值为:(65535 + 3000)/6000 = 11.4225,除以SFB_MAX_PROB的话,相当于0.000174。

#define SFB_MAX_PROB 0xFFFFstatic const struct tc_sfb_qopt sfb_default_ops = {.rehash_interval = 600 * MSEC_PER_SEC,.warmup_time = 60 * MSEC_PER_SEC,.limit = 0,.max = 25,.bin_size = 20,.increment = (SFB_MAX_PROB + 500) / 1000, /* 0.1 % */.decrement = (SFB_MAX_PROB + 3000) / 6000,

以下为Pm的增减函数prob_plus和prob_minus,其取值范围为:[0, 65535]。

static u32 prob_plus(u32 p1, u32 p2)
{u32 res = p1 + p2;return min_t(u32, res, SFB_MAX_PROB);
}static u32 prob_minus(u32 p1, u32 p2)
{return p1 > p2 ? p1 - p2 : 0;
}

SFB哈希扰数

如下函数sfb_swap_slot,在切换slot时,更新之前使用的slot的扰数值(perturbation),关闭双缓存预热开关。

static void sfb_init_perturbation(u32 slot, struct sfb_sched_data *q)
{q->bins[slot].perturbation = prandom_u32();
}static void sfb_swap_slot(struct sfb_sched_data *q)
{sfb_init_perturbation(q->slot, q);q->slot ^= 1;q->double_buffering = false;
}

非响应性流限速

如果penalty_rate或者penalty_burst设置为零,丢弃非响应性流的报文。初始化时tokens_avail设置为与penalty_burst相同的值,token_time为初始化时的时间戳。所以,开始时一直递减可用的token值(tokens_avail),并且不丢报文,不限速。当前tokens_avail递减到小于1时,检查经过了多长时间(不大于10秒钟),根据此时间长度更新可用的令牌值,其值不能大于penalty_burst给出的上限值。tokens_avail小于1时,进行限速。

static bool sfb_rate_limit(struct sk_buff *skb, struct sfb_sched_data *q)
{if (q->penalty_rate == 0 || q->penalty_burst == 0)return true;if (q->tokens_avail < 1) {unsigned long age = min(10UL * HZ, jiffies - q->token_time);q->tokens_avail = (age * q->penalty_rate) / HZ;if (q->tokens_avail > q->penalty_burst)q->tokens_avail = q->penalty_burst;q->token_time = jiffies;if (q->tokens_avail < 1)return true;}q->tokens_avail--;return false;

内核版本 5.0

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 英文日记2020/07/13

    Today, I made a stock account, which means I can make money through it. However, I don’t know the rules now. There’re so many things needed to learn. What’s more, I think it’s time to learn money management. It’s a big problem throughout your life. Fi…...

    2024/4/30 7:33:47
  2. vscode配置代码注释插件和代码格式化插件

    1. 打开vscode配置的方法 在vscode界面按F1键打开命令面板,输入settings,选择Open Settings(JSON)(这个是全局生效的配置,如果选择Open Workspace Settings(JSON)则只对当前工作空间生效,建议选择全局配置) 2. 代码注释插件配置打开Extensions侧边栏,搜索koroFileHeader插件并…...

    2024/5/2 5:13:34
  3. C++知识点-线程3-线程锁

    线程锁的第一个版本#include <thread> #include <string> #include <mutex> #include <iostream> using namespace std;std::mutex mu;void shared_print(string msg, int id) {mu.lock();cout << msg.c_str() << id << endl;mu.unl…...

    2024/4/18 4:18:16
  4. 苏嵌实训-嵌入式 linux C 【第7天】

    项目名称 苏嵌实训-嵌入式 linux C 【第7天】今日进度以及任务 理解操作系统中进程和线程的概念,熟悉Linux下的文件,文件的创建,读写本日任务完成情况在线程和进程的概念方面理解地不错,但是应用起来的时候还是不会;对Linux下的文件有了更深一步的理解本日开发中出现的…...

    2024/4/30 7:37:00
  5. C#开发之——while循环(13)

    一 概述C# while循环与for循环类似,但是while循环一般适用于不固定次数的循环<!--more-->二 while 循环语法形式2.1 语法形式<span style="color:#333333">while(布尔表达式) {语句块; }</span>while 语句执行的过程是,当while中布尔表达式的结果…...

    2024/5/1 18:46:25
  6. koa中使用sequelize,mysql

    1、安装sequelize,mysql2 npm i sequelize mysql2 --save 2、数据库配置3、定义模型4、使用具体参考 sequelize 中文文档 https://itbilu.com/nodejs/npm/V1PExztfb.html#api-create 例子具体参考 https://blog.csdn.net/qq_36718999/article/details/100008416 https://blo…...

    2024/4/6 3:46:16
  7. 【2】WiFi——————ESP8266 SDK编程 之 UDP协议通信client

    简述UDP介绍请点击此链接-————> TCP/IP协议之————>UDPUDP分类udp client 本例程方式udp serverESP有三种工作模式0x01: Station 模式 只能连接路由器,不能被其他设备连接,比如用于UDP通信0x02: SoftAP 模式 自身是个路由器,可以被其他设备连接0x03: St…...

    2024/4/28 12:19:52
  8. Linux网络服务——PXE高效批量网络装机(PXE远程安装与kickstart无人值守安装)

    文章目录部署PXE远程安装服务搭建PXE远程安装服务器服务器的批量部署的优点PXE网络配置PXE装机服务器上面都是废话 实验直接搞起实现Kickstart无人值守安装关于Fkickstart准备安装应答文件实现批量自动装机 部署PXE远程安装服务 PXE由DHCP TFTP VSFTPD 三个服务构建而来 搭建…...

    2024/4/26 0:42:21
  9. cmake

    project demo # 项目信息 aux_source_directory(. DIR_SRCS)#设置变量 add_executable(Demo ${DIR_SRCS}) 当前目录所有源文件赋值给变量 add_executable(Demo main.c math.cc) 指定若干个文件生成可执行文件 add_subdirectory(math) math为目录 也有Cmake_list.txt,来生…...

    2024/4/30 7:34:59
  10. 【SpringMvc】REST风格会出现的一个问题

    JSPs only permit GET POST or HEAD 当出现这个问题的时候,是因为Tomcat8.0及以上版本不支持PUT和DELETE请求方式。 只需要在请求跳转的页面加上 isErrorPage="true参数就可以了 <%@ page language="java" contentType="text/html; charset=UTF-8"…...

    2024/4/23 21:52:10
  11. 物联网工程实训博客day-7

    物联网工程实训博客day-7Linux小白进阶-9日报表 Linux小白进阶-9 日报表项目名称 【苏嵌实训-嵌入式 linuxC 第7天】今日进度以及任务 嵌入式Linux文件编程、多进程编程本日任务完成情况 (详细说明本日任务是否按计划完成,开发的代码量) 课堂任务完成。本日开发中出现的问题…...

    2024/4/8 9:26:29
  12. C#开发之——do while循环(14)

    一 概述C# do while循环可以说时C# while循环的另一个版本,与while循环最大的区别是它至少会执行一次<!--more-->二 do while 语法形式2.1 语法形式<span style="color:#333333">do {语句块; }while(布尔表达式);</span>do while语句执行的过程是…...

    2024/4/24 4:47:54
  13. Java并发编程的艺术-----Java并发编程基础(线程简介)

    Java并发编程基础(线程简介)一、什么是线程二、为什么要使用多线程三、线程优先级四、线程的状态五、Daemon线程 一、什么是线程 操作系统在运行一个程序时,会为其创建一个进程。例如,启动一个Java程序,操作系统会创建一个Java进程。现代操作系统调度的最小单元是线程,也…...

    2024/4/30 7:30:30
  14. 牛客网剑指offer习题(最小的k个数&里连续子数组的最大和)

    输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。 分析: 首先是对数组进行排序,在筛选出值最小的k个数。 import java.util.ArrayList; import java.util.Stack; import java.util.SortedSet; import java.util.Arrays; pu…...

    2024/4/6 3:45:13
  15. php--如何删除目录

    <span>shan chu mu lu he wen jian</span> <hr> <?php function full_rmdir($dir_name) {//打开目录成功if ($handle = @opendir($dir_name)){//获得当前工作目录,保存$old_doc = getcwd();//将传入目录,设置为当前目录chdir($dir_name);//循环打开下级…...

    2024/4/11 22:37:09
  16. 【Redis】Redis Jedis实现发布订阅功能

    1.概述 Redis为我们提供了publish/subscribe(发布/订阅)功能。我们可以对某个channel(频道)进行subscribe(订阅),当有人在这个channel上publish(发布)消息时,redis就会通知我们,这样我们可以收到别人发布的消息。 作为Java的redis客户端,Jedis提供了publish/subscribe的接口…...

    2024/4/30 7:34:47
  17. 防抖节流

    概念: 函数防抖(debounce):触发高频事件后n秒内函数只会执行一次,如果n秒内高频事件再次被触发,则重新计算时间。 函数节流(throttle):高频事件触发,但在n秒内只会执行一次,所以节流会稀释函数的执行频率。 函数节流(throttle)与 函数防抖(debounce)都是为了限制函数…...

    2024/5/2 6:53:25
  18. Linux串口编程短信篇(四) ——— 实现最简单的4G模块短信发送

    文章目录一. 像手机一样发送短信1.1 看看效果 1.2 提出问题二. 主程序的实现2.1 获取并解析命令行参数2.2 识别中英文短信 三. 流程图和源码3.1 流程图3.2 主程序代码四. makefile 及 其他功能 一. 像手机一样发送短信 1.1 看看效果 在介绍main程序之前,先来看一下效果吧~其中…...

    2024/4/30 7:33:01
  19. 高校信息爬虫

    一、目标/目的从学信网的院校信息库中爬取国内高校的信息:学校名称、校徽图片、所在地、类型(综合/工科/医科、92、双一流等),并存储下来。二、遇到的坑同一网页(部分院校主要信息页面,以北京大学为例)电脑端和手机端显示的内容不一样:手机端全都是显示该学校的校徽,而…...

    2024/4/30 7:30:53
  20. 小谈 MySQL 第七话·高可用架构(Mycat+MHA+LVS)

    写在最前:该篇文章还未完成,待进一步更新...。。一、初始 Mycat+MHA+LVS1、为什么选择 Mycat?互联网的高速发展使分布式技术兴起,当系统的压力越来越大时,人们首先想到的解决方案就是想上扩展(scale up),简单说就是不断增加硬件性能来解决这个问题,采用这种方案的硬件…...

    2024/4/23 20:53:53

最新文章

  1. 状态模式

    文章目录 1.UML类图2.状态基类3.状态实现类3.状态机管理类使用示例 1.UML类图 2.状态基类 public abstract class State {public string? Name { get; set; }public StateMachine? StateMachine {get; set;}public abstract void Exit();public abstract void Enter(); }3.…...

    2024/5/2 12:18:52
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 微服务-2 Eureka

    Eureka 启动页面&#xff1a; 同理再注册完order-service后&#xff0c;刷新启动页面&#xff1a; userservice 启动多台服务&#xff1a; [ 代码 ]&#xff1a;orderService.java&#xff08;用 RestTemplate 调其他服务&#xff0c;用 userservice 代替 localhost:8081&…...

    2024/5/1 8:26:19
  4. C# 抽象类、接口

    &#xff08;1&#xff09;、抽象类和抽象方法的定义和实现&#xff1a;abstract override abstract class Vehicle{ public abstract void Run(); } 继承抽象类并且实现抽象方法 class RaceCar : Vehicle{ public override void Run(){ } } &#xff08;2&#xff09;、接口的…...

    2024/5/2 2:42:37
  5. 【C++】C++中的list

    一、介绍 官方给的 list的文档介绍 简单来说就是&#xff1a; list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代。list的底层是双向链表结构&#xff0c;双向链表中每个元素存储在互不相关的独立节点中&#xff0c;在节点中…...

    2024/5/2 2:35:45
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/2 11:19:01
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/1 13:20:04
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/1 21:18:12
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/2 9:47:31
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/2 9:47:31
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/2 6:03:07
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/2 9:47:30
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/1 11:24:00
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/2 5:31:39
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/1 20:22:59
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/2 9:47:28
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/2 9:47:27
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/2 0:07:22
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/2 8:37:00
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/2 9:47:26
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/2 9:47:25
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/1 14:33:22
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/1 11:51:23
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/2 7:30:11
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/1 20:56:20
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57