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

Redis能抗住百万并发的秘密

前言

今天想和大家深入聊聊Redis为什么能够轻松抗住百万级别的并发请求。

有些小伙伴在工作中可能遇到过这样的场景:系统访问量一上来,数据库就扛不住了,这时候大家第一时间想到的就是Redis。

但你有没有想过,为什么Redis能够承受如此高的并发量?它的底层到底做了什么优化?

今天我们就从浅入深,一步步揭开Redis高性能的神秘面纱。

1. Redis高并发的核心架构

1.1 单线程模型的威力

有些小伙伴可能会疑惑:Redis是单线程的,为什么还能支持这么高的并发?

这里需要澄清一个概念,Redis的"单线程"指的是网络IO和键值对读写是由一个线程来完成的,但Redis的整个系统并不是只有一个线程。

image

为什么单线程反而更快?

  1. 避免了线程切换的开销:多线程环境下,CPU需要在不同线程间切换,这个过程需要保存和恢复线程上下文,开销很大。

  2. 避免了锁竞争:单线程模型下,不需要考虑线程安全问题,避免了各种锁的开销。

  3. CPU缓存友好:单线程执行时,CPU缓存命中率更高,减少了内存访问延迟。

让我们看一个简单的对比:

// 多线程模式下的伪代码
public class MultiThreadRedis {private final Object lock = new Object();private Map<String, String> data = new HashMap<>();public String get(String key) {synchronized(lock) {  // 需要加锁return data.get(key);}}public void set(String key, String value) {synchronized(lock) {  // 需要加锁data.put(key, value);}}
}// Redis单线程模式下的伪代码
public class SingleThreadRedis {private Map<String, String> data = new HashMap<>();public String get(String key) {return data.get(key);  // 无需加锁}public void set(String key, String value) {data.put(key, value);  // 无需加锁}
}

1.2 事件驱动模型

Redis采用了事件驱动的架构,基于Reactor模式实现。

这种模式的核心思想是:用一个线程来处理多个连接的IO事件。

image

事件驱动的优势:

  1. 高效的IO多路复用:一个线程可以同时监听多个socket连接
  2. 非阻塞IO:不会因为某个连接的IO操作而阻塞整个程序
  3. 内存占用少:相比多线程模型,节省了大量线程栈空间

2. 内存数据结构的极致优化

2.1 高效的数据结构设计

Redis的高性能很大程度上得益于其精心设计的内存数据结构。

每种数据类型都有多种底层实现,Redis会根据数据的特点自动选择最优的存储方式。

image

让我们深入了解几个关键的数据结构:

2.1.1 SDS (Simple Dynamic String)

有些小伙伴可能不知道,Redis并没有直接使用C语言的字符串,而是自己实现了SDS。

// Redis SDS结构
struct sdshdr {int len;        // 字符串长度int free;       // 未使用空间长度char buf[];     // 字符串内容
};

SDS的优势:

  1. O(1)时间复杂度获取长度:直接读取len字段
  2. 预分配空间:减少内存重新分配次数
  3. 二进制安全:可以存储任意二进制数据
  4. 兼容C字符串函数:以空字符结尾

2.1.2 跳跃表 (Skip List)

跳跃表是Redis中有序集合的核心数据结构,它的查找效率可以达到O(log N)。

image

跳跃表的查找过程:

// 跳跃表查找伪代码
public Node search(int target) {Node current = header;// 从最高层开始查找for (int level = maxLevel; level >= 0; level--) {// 在当前层向右移动,直到下一个节点大于目标值while (current.forward[level] != null && current.forward[level].value < target) {current = current.forward[level];}}// 移动到下一个节点current = current.forward[0];if (current != null && current.value == target) {return current;}return null;
}

2.2 内存优化策略

2.2.1 压缩列表 (ziplist)

当Hash、List、ZSet的元素较少时,Redis会使用压缩列表来节省内存。

image

压缩列表的优势:

  1. 内存紧凑:所有元素连续存储,减少内存碎片
  2. 缓存友好:连续内存访问,CPU缓存命中率高
  3. 节省指针开销:不需要存储指向下一个元素的指针

2.2.2 整数集合 (intset)

当Set中只包含整数元素时,Redis使用整数集合来存储。

// 整数集合结构
typedef struct intset {uint32_t encoding;  // 编码方式uint32_t length;    // 元素数量int8_t contents[];  // 元素数组
} intset;

编码方式自动升级:

// 整数集合编码升级示例
public class IntSetExample {// 初始状态:所有元素都是16位整数// encoding = INTSET_ENC_INT16// contents = [1, 2, 3, 4, 5]// 添加一个32位整数public void addLargeNumber() {// 自动升级为32位编码// encoding = INTSET_ENC_INT32// 重新分配内存,转换所有现有元素}
}

3. 网络IO优化

3.1 IO多路复用技术

Redis在不同操作系统上使用不同的IO多路复用技术:

  • Linux: epoll
  • macOS/FreeBSD: kqueue
  • Windows: select

image

epoll的优势:

  1. 事件驱动:只有当socket有事件时才会通知应用程序
  2. 高效轮询:不需要遍历所有文件描述符
  3. 支持边缘触发:减少系统调用次数

3.2 客户端输出缓冲区

Redis为每个客户端维护输出缓冲区,避免慢客户端影响整体性能。

image

缓冲区配置示例:

# redis.conf配置
# 普通客户端缓冲区限制
client-output-buffer-limit normal 0 0 0# 从服务器缓冲区限制  
client-output-buffer-limit replica 256mb 64mb 60# 发布订阅客户端缓冲区限制
client-output-buffer-limit pubsub 32mb 8mb 60

4. 内存管理优化

4.1 内存分配器选择

Redis支持多种内存分配器,默认使用jemalloc,这是一个专门为多线程应用优化的内存分配器。

image

4.2 过期键删除策略

Redis采用惰性删除和定期删除相结合的策略来处理过期键。

image

定期删除算法:

// Redis定期删除伪代码
public void activeExpireCycle() {int maxIterations = 16; // 最大检查数据库数int maxChecks = 20;     // 每个数据库最大检查键数for (int i = 0; i < maxIterations; i++) {RedisDb db = server.db[i];int expired = 0;for (int j = 0; j < maxChecks; j++) {String key = db.expires.randomKey();if (key != null && isExpired(key)) {deleteKey(key);expired++;}}// 如果过期键比例小于25%,跳出循环if (expired < maxChecks / 4) {break;}}
}

5. 持久化优化

5.1 RDB持久化

RDB是Redis的默认持久化方式,它会在指定的时间间隔内生成数据集的时点快照。

image

RDB的优势:

  1. 紧凑的文件格式:适合备份和灾难恢复
  2. 快速重启:恢复速度比AOF快
  3. 对性能影响小:使用子进程进行持久化

5.2 AOF持久化

AOF通过记录服务器执行的所有写操作命令来实现持久化。

image

AOF重写优化:

// AOF重写示例
public class AOFRewrite {// 原始AOF文件可能包含:// SET key1 value1// SET key1 value2  // SET key1 value3// DEL key2// SET key2 newvalue// LPUSH list a// LPUSH list b// LPUSH list c// 重写后的AOF文件:// SET key1 value3// SET key2 newvalue  // LPUSH list c b apublic void rewriteAOF() {// 遍历所有数据库for (RedisDb db : server.databases) {// 遍历所有键for (String key : db.dict.keys()) {Object value = db.dict.get(key);// 根据值的类型生成对应的命令generateCommand(key, value);}}}
}

6. 集群和分片优化

6.1 Redis Cluster

Redis Cluster是Redis的官方集群解决方案,采用无中心化的架构。

image

哈希槽分配算法:

public class RedisClusterSlot {private static final int CLUSTER_SLOTS = 16384;public int calculateSlot(String key) {// 检查是否有哈希标签int start = key.indexOf('{');if (start != -1) {int end = key.indexOf('}', start + 1);if (end != -1 && end != start + 1) {key = key.substring(start + 1, end);}}// 计算CRC16校验和int crc = crc16(key.getBytes());return crc % CLUSTER_SLOTS;}// CRC16算法实现private int crc16(byte[] data) {int crc = 0x0000;for (byte b : data) {crc ^= (b & 0xFF);for (int i = 0; i < 8; i++) {if ((crc & 0x0001) != 0) {crc = (crc >> 1) ^ 0xA001;} else {crc = crc >> 1;}}}return crc & 0xFFFF;}
}

6.2 分片策略

有些小伙伴在设计分片策略时,可能会遇到数据倾斜的问题。

Redis提供了多种分片方式:

image

7. 性能监控和调优

7.1 关键性能指标

image

性能监控命令:

# 查看Redis信息
INFO all# 监控实时命令
MONITOR# 查看慢查询日志
SLOWLOG GET 10# 查看客户端连接
CLIENT LIST# 查看内存使用情况
MEMORY USAGE keyname# 查看延迟统计
LATENCY LATEST

7.2 性能调优建议

内存优化:

# redis.conf优化配置# 启用内存压缩
hash-max-ziplist-entries 512
hash-max-ziplist-value 64list-max-ziplist-size -2
list-compress-depth 0set-max-intset-entries 512zset-max-ziplist-entries 128
zset-max-ziplist-value 64# 内存淘汰策略
maxmemory-policy allkeys-lru# 启用内存压缩
rdbcompression yes

网络优化:

# TCP相关优化
tcp-keepalive 300
tcp-backlog 511# 客户端超时
timeout 0# 输出缓冲区限制
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60

8. 故障处理和高可用

8.1 故障检测机制

image

8.2 数据一致性保证

主从复制机制:

// Redis主从复制流程
public class RedisReplication {// 全量同步public void fullResync() {// 1. 从服务器发送PSYNC命令// 2. 主服务器执行BGSAVE生成RDB文件// 3. 主服务器将RDB文件发送给从服务器// 4. 从服务器载入RDB文件// 5. 主服务器将缓冲区的写命令发送给从服务器}// 增量同步public void partialResync() {// 1. 从服务器发送PSYNC runid offset// 2. 主服务器检查复制偏移量// 3. 如果偏移量在复制积压缓冲区内,执行增量同步// 4. 主服务器将缓冲区中的数据发送给从服务器}
}

总结

通过以上深入分析,我们可以看到Redis能够抗住10万并发的核心原因包括:

架构层面

  1. 单线程模型:避免了线程切换和锁竞争的开销
  2. 事件驱动:基于epoll的IO多路复用,高效处理大量连接
  3. 内存存储:所有数据存储在内存中,访问速度极快

数据结构层面

  1. 高效的数据结构:针对不同场景优化的数据结构
  2. 内存优化:压缩列表、整数集合等节省内存的设计
  3. 智能编码:根据数据特点自动选择最优存储方式

网络层面

  1. IO多路复用:单线程处理多个连接
  2. 客户端缓冲区:避免慢客户端影响整体性能
  3. 协议优化:简单高效的RESP协议

持久化层面

  1. 异步持久化:不阻塞主线程的持久化机制
  2. 多种策略:RDB和AOF满足不同场景需求
  3. 增量同步:高效的主从复制机制

集群层面

  1. 水平扩展:通过分片支持更大规模
  2. 高可用:主从复制和故障转移
  3. 负载均衡:智能的数据分布算法

有些小伙伴在工作中可能会问:"既然Redis这么强大,是不是可以完全替代数据库?"答案是否定的。

Redis更适合作为缓存和高速数据存储,而不是主要的数据存储。

正确的做法是将Redis与传统数据库结合使用,发挥各自的优势。

最后,要想真正发挥Redis的性能,不仅要了解其原理,更要在实际项目中不断实践和优化。

希望这篇文章能够帮助大家更好地理解和使用Redis。

最后说一句(求关注,别白嫖我)

如果这篇文章对您有所帮助,或者有所启发的话,帮忙关注一下我的同名公众号:苏三说技术,您的支持是我坚持写作最大的动力。

求一键三连:点赞、转发、在看。

关注公众号:【苏三说技术】,在公众号中回复:进大厂,可以免费获取我最近整理的10万字的面试宝典,好多小伙伴靠这个宝典拿到了多家大厂的offer。

本文收录于我的技术网站:http://www.susan.net.cn

相关文章:

Redis能抗住百万并发的秘密

前言 今天想和大家深入聊聊Redis为什么能够轻松抗住百万级别的并发请求。 有些小伙伴在工作中可能遇到过这样的场景:系统访问量一上来,数据库就扛不住了,这时候大家第一时间想到的就是Redis。 但你有没有想过,为什么Redis能够承受如此高的并发量?它的底层到底做了什么优化…...

接受 “未完成态”,是一种能力

正文这个标题,写给你们,也写给我自己。我不知道有多少人有这种类似的问题:我们很难把一个没有写完的字、一件没有完成的事情给别人看。这种做到半路的样子如果拿出来展示的话,非常难为情。尤其是如果还要中途易辙的话,那就更不好解释了。网上经常有那种开玩笑说熬夜的,说…...

深入理解JNI、安全点与循环优化:构建高健壮性Java应用

🔥🔥🔥来都来了 ~ 先赞后看 效果翻倍哦 ~ 👍👍👍 引言 在Java开发者的工具箱中,有一些看似神秘却极其重要的底层概念。你是否曾听说过在循环中插入Thread.sleep(0)可以"唤醒"GC?或者疑惑为什么一个简单的循环计数器类型选择会影响整个应用的稳定性?本…...

英语_阅读_fascinating facts about water_待读

Did you know these fascinating facts about water? They might change the way you think about every drop!你知道这些关于水的奇妙事实吗?它们可能会改变你对每一滴水的看法! Scientists have discovered something incredible - the amount of water on the Earth toda…...

AI自动化测试全攻略:从AI 自动化测试实战到AI 智能测试平台开发!

最新一期 AI + 全栈测试开发训练营震撼来袭,课程内容全面升级,月薪轻松对标 30k + !今日开放 5 个特价名额,零基础小白与测试老司机皆可在此找到专属学习路径,涵盖从AI 自动化测试实战到AI 智能测试平台开发等前沿内容,覆盖 AI 时代测试开发核心能力,帮你构建完整知识体…...

LG9691

考虑 dp。设 \(f_i\) 表示到位置 \(i\) 所需的最小花费,且第 \(i\) 个位置必选,现在要找上一个决策点 \(j\),这个点应该要在此前所有区间的左端点的后面,才能保证这些区间能被覆盖(即确保至少一个在之前每个区间内),则 \(j\) 应满足 \(\max_{r_k<i}l_k \le j < i\…...

即时通讯小程序 - 实践

即时通讯小程序 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", monospace !important; font-size: 1…...

PHP serialize 序列化完全指南

PHP serialize 序列化完全指南 介绍 如果你和我一样,第一次在 PHP 中看到序列化字符串时会觉得很困惑。我当时在做一个 Laravel 项目,想搞清楚将任务推送到队列时到底发生了什么。我发现一些数据被序列化了,但不知道为什么以及怎么工作的。不过在我花时间研究序列化后,发现…...

CF2112D

注意到一条边无论方向如何,都能使两端的某一个点到达另一个点,即至少有 \(n-1\) 对。如果只需要 \(n-1\) 对,那么只需要在每一条链上相邻的边方向相反即可。对于剩下的一对,我们可以找到一个度数为 \(2\) 的点,并把连接的两条边由反向改为同向,那么附近的三个点产生的对数…...

CF2112C

设 Alice 取的位置为 \(i,j,k\) 且 \(i<j<k\),则 Bob 的最优策略有两种:取 \(n\) 或 \(k\)。为了使 Alice 必胜,必须同时满足 \(a_i+a_j+a_k>a_n,a_i+a_j>a_k\)。枚举 \(i,j\),显然满足两个条件的 \(k\) 都是一段连续的区间。分别二分算出两个区间的边界,那么…...

CF342C

显然,每一层恰好能放下两个球(事实上这也是最优的方案),那么下面一共可以放 \(\lfloor \frac{h}{r} \rfloor \times 2\) 个球,剩余 \(h - \lfloor \frac{h}{r} \rfloor \times r+r\) 的高度,记 \(h=h-\lfloor \frac{h}{r} \rfloor\times r\) 为立方体部分剩余高度。最上面…...

ICPC/XCPC 做题记录

[SNCPC2019] Unrooted Trie 发现不满足题意的情况就是一个节点到多个子节点的边的字母相同,那么合法当且仅当每个节点到子节点的字母互不相同。那么可以统计每个节点连接的字母数量,并运用类似换根 dp 的思路,快速更新这个数量并实时维护符合条件的点的数量即可。时间复杂度…...

LG9648

发现不满足题意的情况就是一个节点到多个子节点的边的字母相同,那么合法当且仅当每个节点到子节点的字母互不相同。那么可以统计每个节点连接的字母数量,并运用类似换根 dp 的思路,快速更新这个数量并实时维护符合条件的点的数量即可。时间复杂度 \(O(nA)\),其中 \(A=26\) …...

LG5689

设 \(f_u\) 表示以 \(u\) 为根的子树构成不同多叉堆的方案数。显然最小的 \(0\) 应该分配给 \(u\),剩下的分给子节点 \(v_1,v_2,\cdots,v_k\),根据乘法原理,有 \[f_u=\prod_{i=1}^k \binom{siz_u-1-\sum_{j=1}^{i-1}siz_{v_j}}{siz_{v_i}}f_{v_i} \]将组合数和 \(f\) 分开,…...

近五年 CSP NOIP 补题记录

2025.6.18 NOIP2024 T4 树上查询 To be updated. Submission CSP-S2019 江西 T3 网格图 To be updated. Submission 2025.6.19 CSP-S2019 D1T2 括号树 To be updated. Submission CSP-S2021 T3 回文 To be updated. Submission CSP-S2019 江西 T1 日期 To be updated. Submissi…...

CF2111C

显然,操作的方式一定是一段数字相等的极长连续段向左右拓展(包括长度为 \(1\) 的段)。故只需扫一遍并维护每段的值和长度即可,并更新答案。时间复杂度 \(O(\sum n)\)。 #include<iostream> #include<cstdio> #define int long long #define N 500010 using nam…...

唐人日记

唐注意看函数返回值!!!!!!!...

CF2111B

首先最大的 \(f_n\) 必须放的下,即 \(f_n \le \min(w,l,h)\)。此外,\(f_{n-1}\) 紧贴在 \(f_n\) 的一个面上,故要 \(f_n+f_{n-1} \le \max(w,l,h)\)。剩下的第 \(i\) 个正方体由于满足 \(f_{i+2}=f_{i}+f_{i+1}\),故只需与第 \(i+1,i+2\) 个正方体共用一条棱即可,且一定不…...

ABC394F

在同一棵树中,选择任意一个点作为根,效果都是相同的。不妨以 \(1\) 为树根,考虑树上 dp,记 \(f_u\) 为以 \(u\) 为根的子树的点数最大值。注意到根节点度数可为 \(1\) 可为 \(4\),而非根非叶子节点度数必须为 \(4\)。由此可以分两类转移。假设子树中 \(u\) 度数为 \(1\),…...

LG11793

注意到 \(N \times M \le 2\times 10^7\),因此不难得到一个 dp 做法。设 \(f_i\) 表示把前 \(i\) 个橙子装进箱子内的最小成本,则不难得到以下转移式: \[f_i=\min_{i-j\le m,0 \le j < i} f_j+k+ ( i - j ) \times ( \max_{j < k \le i} a_k - \min_{j < k \le i} …...

ABC394G

题目要求最小化爬楼梯的次数,那么我们就要让楼层的变化尽量小,即沿线楼房高度越高越好。不难发现影响答案的是路线中的楼房高度的最小值,则需要最大化最小值。那么就不难用 Kruskal 重构树做了。对每个点进行唯一编号,相邻的点建边权为较小的的楼房高度的双向边。剩下的就是…...

MX 炼石 2026 NOIP #5

qwq2026 --【炼石计划 NOIP】-- 第五套 链接:link 题解:link 时间:4h (2025.09.11 14:00~18:00) 题目数:4 难度:A B C D估分:[40,60] + 80 + 32 + ? = [152,172]+? 得分:40 + 60 + 32 + 10 = 142 Rank:场祭补题天依宝宝可爱!...

0126_状态模式(State)

状态模式(State) 意图 允许对象在内部状态改变时改变它的行为。对象看起来似乎修改了它的类。 UML 图优点行为与状态绑定:将特定状态下的行为局部化到对应的状态类中 消除条件判断:避免了大量的if-else状态判断逻辑 状态转换明确:使状态转换流程更加清晰和可管理 易于扩展:…...

Visual Studio 2026 预览体验版现已发布,一起来看看带来哪些新功能!

前言 2025 年 9 月 9 日微软 Visual Studio 团队正式推出了 Visual Studio 2026 预览体验版(Visual Studio 2026 Insiders),此次发布标志着 Visual Studio 迎来一个全新的时代,它将人工智能深度集成到平台中,基础功能更强大,性能也得到进一步提升。 下载 Visual Studio 2…...

基于RK3568/RK3576/RK3588/全志H3/飞腾芯片/国产UOS等/国标GB28181监控系统

一、前言说明 之前从最底层协议通信把gb28181实现了一遍,没有用到exosip或者pjsip等任何第三方库,通过熟读gb28181国标文档几百页,看了一遍又一遍,根据对应的官方文档,一行行代码底层实现,其实就是网络通信,可选tcp或者udp,和http都是同类型的协议,有消息头和消息体,…...

Go语言读写锁(RWMutex)底层原理详解

Go语言读写锁(RWMutex)底层原理详解 概述 Go语言的sync.RWMutex是一种读写锁,允许多个读操作同时进行,但写操作是互斥的。这种锁机制在读多写少的场景下能显著提高并发性能。底层通过互斥锁和原子计数器实现复杂的并发控制。 核心数据结构 type rwmutex struct {rLock m…...

【GitHub每日速递】无需提示词!Nano Bananary香蕉超市:AI绘画玩法多到停不下来

原文:【GitHub每日速递】无需提示词!Nano Bananary香蕉超市:AI绘画玩法多到停不下来 AutoGPT来袭!搭建、部署、运行AI智能体全攻略揭秘 AutoGPT 是一个基于自主任务执行的AI代理工具。简单讲,它能让AI自动拆解目标并执行一系列操作来完成任务,无需持续人工干预。适用人群…...

小题狂练 (J)

solset-J\[\newcommand{\diag}{\operatorname{diag}} \]目录 目录[AGC070B] Odd Namori[JOI Open 2025] 冒泡排序机 / Bubble Sort Machine[AGC039F] Min Product Sum[AGC070B] Odd NamoriMatrix-Tree 定理:给一张带权有向图 \(G\),求 \(G\) 所有以 \(1\) 为根的内向生成树边…...

Drift数据库开发实战:类型安全的SQLite解决方案

Drift数据库开发实战:类型安全的SQLite解决方案本文基于BeeCount(蜜蜂记账)项目的实际开发经验,深入探讨如何使用Drift构建类型安全、高性能的Flutter数据库层。项目背景 BeeCount(蜜蜂记账)是一款开源、简洁、无广告的个人记账应用。所有财务数据完全由用户掌控,支持本地存…...

DELPHI FireDAC连接EXCEL文件

重要提示: xls后缀的文件与xlsx后缀的文件,连接方法不一样. 可以使用代码来实现:FDConnection1.Connected := false;FDConnection1.Params.Clear;FDConnection1.DriverName := ODBC;FDConnection1.Params.Values[DriverID] := ODBC;FDConnection1.Params.Values[ODBCDriver] :=…...

读人形机器人09教育行业

读人形机器人09教育行业1. 教育行业 1.1. 教育是社会进步的基石,是指引后代走向启蒙与创新的明灯 1.2. 人形机器人通过使学习互动化、沉浸化、趣味化,革新了教学方法 1.3. 借助技术创造兼具教育性与吸引力的体验,培养学生成为主动学习者和批判性思考者 2. 个性化学习体验 2.…...

PHP判断字符串是否包含中文

function hasChinese($str) { return preg_match(/[\x{4e00}-\x{9fa5}]/u, $str);} // 使用示例$string = "Hello 你好";if (hasChinese($string)) { echo "字符串包含中文";} else { echo "字符串不包含中文";}每天进步一点点...

当我们红尘作伴,活得潇潇洒洒

为了证明我是真的睡不着而非摆到凌晨三点,先来一点正经东西。平面等腰直角三角形加,查询矩形和。经典问题,但我刚刚才会。考虑矩形加矩形和是咋做的,通过一堆拆拆拆把 4-side 变成 2-side,然后扫描线扫掉一维,数据结构维护另一维。那等腰直角三角形肯定也要拆拆拆。认为下…...

诡异的mysql8的问题

同样是使用 mysql8的镜像 在其他三台服务器上能正常执行druid:initial-size: 5min-idle: 5max-active: 20max-wait: 60000# 调整为 1800000 毫秒 (30 分钟),需大于数据库 wait_timeoutmin-evictable-idle-time-millis: 1800000# 调整检查间隔为 120000 毫秒 (2 分钟)time-betwe…...

二叉树理论

满二叉树:只有度数为0或者2的节点,并且度数为0的节点在同一层;完全二叉树 除了底层节点可能没填满以外其他都填满了,并且最下面一层的节点都集中在该层最左边的若干位置。 之前我们刚刚讲过优先级队列其实是一个堆,堆就是一棵完全二叉树,同时保证父子节点的顺序关系。 二…...

支付中心的熔断降级要怎么做

下面我会把支付中心在流量骤增 / 下游通道故障时的熔断与降级策略拆成(1)原则与常见策略,(2) 业务级降级/路由策略,(3) 具体落地组件(行业实践与参考),以及(4)可直接落地的 Java 示例(使用 Resilience4j + fallback + 速率限制 + 隔离)。 1) 基本原则(5 条行业共识…...

协议版iM蓝号检测,批量筛选iMessages数据,无痕检测是否开启iMessage服务

一、实现iMessage数据检测的两种方式:1.人工筛选,将要验证的号码输出到文件中,以逗号分隔。再将文件中的号码粘贴到iMessage客户端的地址栏,iMessage客户端会自动逐个检验该号码是否为iMessage账号,检验速度视网速而定。红色表示不是iMessage账号,蓝色表示iMessage账号。2…...

栈和队列总结

栈和队列理论C++中stack,queue 是容器么? 我们使用的stack,queue是属于那个版本的STL? 我们使用的STL中stack,queue是如何实现的? stack,queue 提供迭代器来遍历空间么?stack和queue是STL中的容器适配器,不是类似list,vector那样的容器; 容器适配器本质上是基于底层真…...

工业互联网认知实训台-一句话介绍

工业互联网认知实训台主要由传感器、PLC控制器、工业以太网设备、人机界面(HMI)、步进电机和伺服电机等设备组成。步进电机:通过电脉冲信号控制电机每步旋转固定角度,结构简单、成本低,适合精确定位,但效率较低且可能失步。实训台中使用PLC(如1212C系列)通过脉冲信号控…...

1

<meta name="description" content="加载中... 如白屏请[ 点击刷新页面 ]"> <meta property="og:description" content="加载中... 如白屏请[ 点击刷新页面 ]"> <meta http-equiv="Cache-Control" content=&…...

湾区杯 SilentMiner WP

攻击者的ip地址查看文件 /var/log/btmp 发现短时间内大量登录,可确定攻击者 ip 为 192.168.145.131 lastb -f /var/log/btmp192.168.145.131攻击者共进行多少次ssh口令爆破失败?根据 /var/log/btmp 文件计数 lastb -f btmp | grep 192.168.145.131 | wc -l也可以在 /var/log/…...

Python-课后题题目-1.1编程世界初探

1.1编程世界初探(单选题) 1.程序设计语言的主要目的是什么? A让计算机变得更便宜 B使人类能够以高效,清晰,结构化的方式表达计算机逻辑和数据操作 C取代数学和逻辑学 D仅用于编写游戏程序 2.机器语言是由什么组成的? A十进制数字 B英文字母 C二进制代码 D特殊符号 3.汇…...

Python-课后题题目-1.2初识python语言

1.2初识python语言(单选题)Python语言最初由谁创建? A.林纳斯托瓦兹 B.吉多范罗苏姆 C.詹姆斯高斯林 D.布雷丹艾奇 Python 0.9.0版本首次发布于哪一年? A.1989 B.1991 C.1994 D.2000 Python 1.0版本引入了以下哪项特性? A.异步编程 B.类型注释 C.循环和异常处理 D.垃圾回收…...

node和npm相关的记录

1 npm install --loglevel verbose 安装的啰嗦模式会打印日志2 3 npm config get registry 查看镜像源信息。 淘宝的镜像源已经关闭了。4 5 #windwos可以安装一个nvm,可以切换node和npm的版本。6 nvm下载地址 https://github.com/coreybutler/nvm-windows/releases7 8 nvm in…...

在Spring boot 中使用@master 设置主从数据库

基础配置 application.ymlspring:  datasource:     master:       url: jdbc:mysql://localhost:3306/master_db       username: root       password: 123456       driver-class-name: com.mysql.cj.jdbc.Driver …...

设计模式-装饰器模式 - MaC

装饰器模式是一种结构型设计模式,它允许在不修改原有对象结构的情况下,动态地给对象添加新的功能。装饰器模式通过创建一个包装对象(装饰器)来包裹真实的对象,从而在运行时扩展对象的功能。 装饰器模式包含以下角色:组件(Component):定义一个对象接口,可以给这些对象动…...

【API接口】最新可用河马短剧接口

最新可用红果短剧接口,支持短剧搜索、短剧详情解析、短剧播放链接解析功能,助您快速构建您的专属短剧客户端 使用之前您需要先去注册下key 申请地址: https://www.52api.cn 接口地址:https://www.52api.cn/api/hm_duanju 返回格式:application/json 请求方式:GET/POST 请…...

第 16 章反射(reflection)

第 16 章反射(reflection)第 16 章反射(reflection) 16.1 一个需求引出反射 16.1.1 请看下面的问题根据配置文件 re.properties 指定信息,创建Cat对象并调用方法hi classfullpath=com.hspedu.Cat method=hi思考:使用现有技术,你能做的吗?这样的需求在学习框架时特别多,即通…...

自我介绍+软工5问

| 这个作业属于哪个课程 | https://edu.cnblogs.com/campus/gdgy/Class12Grade23ComputerScience/join?id=CfDJ8G33EJ5dWE5OhU_7yPrjq1_EG2G2ljnyYNdPWrrB61TEPdvbX8B-02_mm2lbvSH0zHF0AFJBdSQazCWQtYhdASVnPbQZ7mm4BuFr16ksfoeASRJAr16ktj02s3Qx3JGS33oIuJz021Uout0lNo8pyB8 …...

电容器+动生电动势+自由落体模型

电容器电容为 \(C\),磁感应强度为 \(B\),导体棒长度为 \(L\),质量为 \(m\),重力加速度 \(g\)。 设关于时间 \(t\) 的函数 \(E(t),U(t),Q(t),I(t),v(t),a(t)\)。 \[\begin{cases} E(t)=BLv(t)\\ U(t)=E(t)\\ Q(t)=CU(t)\\ I(t)=Q(t)\\ F(t)=mg-BLI(t)\\ a(t)=v(t)=\dfrac{F(…...