深入掌握Redis主从复制:原理、配置与生产级实践指南
一、主从复制核心价值与适用场景
1.1 核心价值矩阵
-
数据安全:多节点冗余存储,避免单点数据丢失
-
服务可用性:主节点故障时可快速切换从节点
-
性能扩展:通过横向扩展从节点提升读吞吐量
-
运维便利:从节点可承担备份、分析等后台任务
1.2 典型应用场景
-
高并发读场景:电商商品详情页读取
-
数据热备份:金融交易数据实时备份
-
读写分离架构:内容平台的写后读场景
-
异地多活基础:跨机房数据同步的基础层
二、主从复制工作原理深度剖析
2.1 全量复制(Full Resynchronization)
完整流程:
-
从节点发送
PSYNC ? -1
命令发起同步请求 -
主节点启动
BGSAVE
生成RDB快照(fork子进程处理) -
RDB文件生成期间,主节点将新写入命令存入复制缓冲区
-
RDB传输完成后,主节点发送缓冲区累积的写命令
-
从节点清空旧数据,加载RDB后执行缓冲命令
关键参数:
repl-backlog-size 1gb # 复制缓冲区大小
repl-backlog-ttl 3600 # 缓冲区保留时间(秒)
client-output-buffer-limit slave 2gb 1gb 60 # 从节点输出缓冲区限制
2.2 增量复制(Partial Resynchronization)
触发条件:
-
从节点断线时间小于
repl-backlog-ttl
-
主节点复制缓冲区包含断线期间的写命令
执行过程:
-
从节点发送
PSYNC <runid> <offset>
-
主节点校验runid和offset有效性
-
主节点发送从offset之后的所有缓冲命令
-
从节点应用这些命令完成同步
偏移量验证:
# 主节点查看复制偏移量
127.0.0.1:6379> info replication
# Replication
role:master
connected_slaves:1
master_repl_offset:387654# 从节点查看偏移量
127.0.0.1:6380> info replication
# Replication
role:slave
master_repl_offset:387654
slave_repl_offset:387654
三、生产环境配置实战
3.1 主节点配置详解
# redis-6379.conf
port 6379
daemonize yes
pidfile /var/run/redis_6379.pid
logfile "/data/redis/logs/master.log"
dir /data/redis/6379
dbfilename dump-6379.rdb# 复制相关
repl-backlog-size 2gb
repl-diskless-sync yes # 无盘复制(适用于SSD)
repl-timeout 60 # 复制超时时间(秒)# 安全设置
requirepass MASTER_P@ssw0rd
masterauth SLAVE_P@ssw0rd # 当从节点需要密码时
3.2 从节点配置优化
# redis-6380.conf
port 6380
daemonize yes
pidfile /var/run/redis_6380.pid
logfile "/data/redis/logs/slave.log"
dir /data/redis/6380# 主从配置
replicaof 192.168.1.100 6379
masterauth MASTER_P@ssw0rd
replica-read-only yes# 性能优化
repl-ping-replica-period 10 # 从节点ping间隔
repl-disable-tcp-nodelay no # 启用小包合并
3.3 动态管理命令集
# 查看复制状态
redis-cli -p 6379 info replication# 动态切换主节点(在从节点执行)
127.0.0.1:6380> REPLICAOF NEW_MASTER_IP 6379# 提升从节点为主节点
127.0.0.1:6380> REPLICAOF NO ONE# 设置复制流压缩(Redis 4.0+)
config set repl-diskless-sync-delay 5
四、读写分离深度实践
4.1 客户端实现方案
Java示例(Jedis):
public class RedisReadWriteSplit {private JedisPool masterPool;private JedisPool slavePool;public void init() {// 主节点连接池JedisPoolConfig config = new JedisPoolConfig();config.setMaxTotal(50);masterPool = new JedisPool(config, "master-host", 6379, 2000, "MASTER_P@ssw0rd");// 从节点连接池slavePool = new JedisPool(config, "slave-host", 6380, 2000, "SLAVE_P@ssw0rd");}public void writeOperation(String key, String value) {try (Jedis jedis = masterPool.getResource()) {jedis.set(key, value);// 同步等待(可选)jedis.waitReplicas(1, 1000); // Redis 3.0+}}public String readOperation(String key) {try (Jedis jedis = slavePool.getResource()) {return jedis.get(key);}}
}
4.2 数据一致性保障策略
-
强制读主模式:关键数据读取时指定从主节点读取
-
时间戳校验:写入时记录时间戳,读取时校验时间差
-
二次读取:当从节点读取失败时降级到主节点
-
延迟监控:实时监控
master_repl_offset
差值
延迟检测脚本:
#!/bin/bash
MASTER_OFFSET=$(redis-cli -h master-host -p 6379 info replication | grep master_repl_offset | cut -d: -f2)
SLAVE_OFFSET=$(redis-cli -h slave-host -p 6380 info replication | grep master_repl_offset | cut -d: -f2)
DELAY=$(($MASTER_OFFSET - $SLAVE_OFFSET))
if [ $DELAY -gt 100000 ]; thenecho "ALERT: Replication delay exceeds 100000 bytes"
fi
五、故障切换全流程演练
5.1 主节点宕机模拟
# 模拟主节点崩溃
redis-cli -h master-host -p 6379 DEBUG SEGFAULT# 观察从节点状态(预期输出)
redis-cli -h slave-host -p 6380 info replication | grep master_link_status
# master_link_status:down
5.2 手动故障转移步骤
-
提升从节点为新主
redis-cli -h slave-host -p 6380 REPLICAOF NO ONE
-
其他从节点重配
redis-cli -h other-slave -p 6381 REPLICAOF slave-host 6380
-
应用配置更新
-
修改客户端连接配置
-
更新DNS或服务发现注册
-
通知监控系统变更拓扑
5.3 数据完整性验证
# 校验键数量
MASTER_KEYS=$(redis-cli -h new-master -p 6380 dbsize)
SLAVE_KEYS=$(redis-cli -h other-slave -p 6381 dbsize)
if [ $MASTER_KEYS -eq $SLAVE_KEYS ]; thenecho "Key count matches"
elseecho "Data inconsistency detected"
fi# 抽样校验数据
redis-cli -h new-master -p 6380 --scan --count 100 | while read key; domaster_val=$(redis-cli -h new-master -p 6380 get $key)slave_val=$(redis-cli -h other-slave -p 6381 get $key)if [ "$master_val" != "$slave_val" ]; thenecho "Mismatch on key: $key"fi
done
六、高级调优与问题排查手册
6.1 性能优化参数矩阵
参数 | 默认值 | 推荐值 | 说明 |
---|---|---|---|
repl-backlog-size | 1mb | 512mb | 增大缓冲区应对网络闪断 |
repl-timeout | 60s | 120s | 适应高延迟网络环境 |
repl-ping-slave-period | 10s | 5s | 加快故障检测速度 |
repl-disable-tcp-nodelay | no | yes | 减少小包数量提升网络效率 |
6.2 常见故障排查表
故障现象 | 诊断命令 | 解决方案 |
---|---|---|
从节点无法连接主节点 | telnet master-host 6379 | 检查防火墙、网络ACL、认证密码 |
主从数据不一致 | info replication 查看offset | 重启复制流程或全量同步 |
复制延迟持续增大 | redis-cli --latency-history | 优化主节点持久化策略,升级带宽 |
从节点内存异常增长 | info memory 分析内存组成 | 检查是否有未授权的持久化操作 |
七、主从架构局限性及应对方案
7.1 典型限制
-
写能力扩展:单主节点写性能受限
-
故障切换延迟:手动切换存在服务中断窗口
-
脑裂风险:网络分区可能导致数据不一致
-
全量同步成本:大数据量时同步耗时显著
7.2 进阶解决方案
-
Redis Sentinel:实现自动故障检测与转移
-
Redis Cluster:分布式写能力扩展方案
-
Proxy方案:使用Twemproxy或Codis实现透明分片
-
混合持久化:AOF与RDB结合降低全量同步风险
八、监控体系建设方案
8.1 核心监控指标
指标类别 | 具体指标 | 告警阈值 |
---|---|---|
节点状态 | master_link_status | 持续down超过30s |
复制延迟 | master_repl_offset差值 | >1MB持续5分钟 |
内存使用 | used_memory_human | >80%总内存 |
网络流量 | instantaneous_input_kbps | >50MB/s持续10分钟 |
8.2 Prometheus监控配置示例
- job_name: 'redis_exporter'static_configs:- targets: ['redis-master:9121', 'redis-slave:9121']metrics_path: /scrapeparams:target: ['redis://master-host:6379', 'redis://slave-host:6380']# 告警规则
groups:
- name: RedisReplicationrules:- alert: HighReplicationLagexpr: redis_master_repl_offset - redis_slave_repl_offset > 1000000for: 5mlabels:severity: criticalannotations:summary: "Redis replication lag high (instance {{ $labels.instance }})"description: "Replication lag is {{ $value }} bytes"
九、生产环境最佳实践清单
-
版本管理:
-
保持主从节点大版本一致
-
升级时先升级从节点,最后升级主节点
-
-
容量规划:
-
主节点内存使用控制在70%以下
-
预留50%带宽用于复制流量
-
-
安全加固:
-
启用SSL加密传输(Redis 6.0+)
-
使用ACL进行细粒度权限控制
-
-
灾备演练:
-
每季度执行全链路故障切换演练
-
建立主从角色快速切换的SOP文档
-
十、知识扩展路线图
-
底层原理:
-
研究Redis事件循环模型
-
理解RDB/AOF持久化机制
-
-
高可用架构:
-
掌握Redis Sentinel原理
-
学习Redis Cluster分片算法
-
-
生态工具:
-
使用RedisBloom实现布隆过滤器
-
集成RediSearch实现全文检索
-
-
云原生实践:
-
Kubernetes部署方案
-
多可用区部署策略
-
通过本文的深度解析,您已掌握Redis主从复制的核心原理与生产级实践技巧。建议在实际部署中结合监控系统与自动化运维工具,构建具备弹性扩展能力的Redis服务架构。
相关文章:
深入掌握Redis主从复制:原理、配置与生产级实践指南
一、主从复制核心价值与适用场景 1.1 核心价值矩阵 数据安全:多节点冗余存储,避免单点数据丢失 服务可用性:主节点故障时可快速切换从节点 性能扩展:通过横向扩展从节点提升读吞吐量 运维便利:从节点可承担备份、分…...
springboot如何管理多数据源?
静态多数据源管理 配置多个数据源 :创建多个数据源的配置类,通常使用 @ConfigurationProperties 注解来绑定配置文件中的数据源属性,并通过 @Bean 注解定义多个 DataSource Bean 。例如: 配置类: @Configuration public class DataSourceConfig {@Bean(name = "prima…...
基于风力推进器控制的小球实验装置设计与研究
目录 完整论文下载链接放在文章结尾,有需要自行下载。 目录 摘 要 1 引 言 2 概述 2.1 风控小球系统概述 2.2 本设计方案思路 2.3 研发方向和技术关键 2.4 主要技术指标 3 总体设计 4 硬件设计 4.1 单片机最小系统 4.2 供电接口电路 4.3 Openmv摄像头…...
Swift闭包(Closure)深入解析与底层原理
前言 在Swift开发中,闭包是一个非常重要且强大的特性。本文将深入探讨Swift闭包的底层实现原理,帮助开发者更好地理解和使用这一特性。 1. 什么是闭包 闭包是自包含的函数代码块,可以在代码中被传递和使用。它不仅可以像函数一样执行代码&…...
【DE-III】基于细节增强的模态内和模态间交互的视听情感识别
abstract 在视听情感识别(AVER)中,捕捉视频和音频模态之间复杂的时间关系是至关重要的。然而,现有的方法缺乏对局部细节的关注,如视频帧之间的面部状态变化,这会降低特征的可区分性,从而降低识别准确率。 为此,本文提出了一种用于AVER的细节增强的模态内和模态间交互…...
c++11 :智能指针
目录 一 为什么需要智能指针? 二 智能指针的使用及原理 1. RAII 2. auto_ptr 3. unique_ptr 4. shared_ptr 5. weak_ptr 三 内存泄漏 1.什么是内存泄漏,内存泄漏的危害 2. 如何避免内存泄漏? 一 为什么需要智能指针? …...
Linux解压tar.gz包的正确姿势(附赠防抓狂指南)
一、为什么你的解压命令总报错? 每次看到.tar.gz后缀是不是心里一紧?(别装了!我都看到你偷偷打开浏览器查命令的样子了)这个在Linux界横行霸道的压缩格式,其实用对了方法比Windows的zip还简单。今天咱们不…...
MCP协议:让AI从“话痨”变“实干家”的神奇魔法
一、MCP 协议:AI 界的 “万能插头” 是啥来头? 1.1 从 “动口不动手” 到 “全能打工人” 你以为 AI 只会陪你聊天、写文案?那你可小瞧它啦!MCP 协议(Model Context Protocol),堪称 AI 的 “瑞…...
如何在SpringBoot中通过@Value注入Map和List并使用YAML配置?
在SpringBoot开发中,我们经常需要从配置文件中读取各种参数。对于简单的字符串或数值,直接使用Value注解就可以了。但当我们需要注入更复杂的数据结构,比如Map或者List时,该怎么操作呢?特别是使用YAML这种更人性化的配…...
记一次调用大华抓拍SDK并发优化
目录 一、问题分析 二、解决思路 三、贴代码 四、总结 一、问题分析 按惯例上问题: 设备告警采用高电平持续模式:一次开,不主动关就一直处于告警状态。 并发时多个请求下发 setDVRAlarmOutConfig,导致状态混乱。 “开 -&g…...
打破认知!没论文没竞赛,我的暑期实习上岸秘籍:简历要敢 “吹”,面试靠巧 “聊”
前言 以下教程仅针对本人的大大小小几十场暑期实习面试的经验总结,个人背景(双9,无论文、无竞赛、无大厂实习、无奖。)。简历几易其稿,相对于原来的初版,可谓是脱胎换骨,洗经易髓。 二月中旬开…...
为何 RAG 向量存储应优先考虑 PostgreSQL + pgvector 而非 MySQL?
构建检索增强生成(RAG)系统已成为释放大型语言模型(LLM)潜力的关键范式。通过将 LLM 的推理能力与外部知识库的实时、特定信息相结合,RAG 能够生成更准确、更相关、更值得信赖的回答。而这个“外部知识库”的核心&…...
LangChain LCEL表达式语言简介
LangChain表达式语言(LCEL)是专为构建AI应用链设计的声明式编程框架,通过管道符|实现组件无缝衔接,支持流式处理、异步调用等生产级特性。其核心优势在于零代码改动实现原型到生产的过渡,同时保持代码简洁性和可维护性…...
智能座舱背后的秘密:智能座舱测试如何“具身智能”
在上期文章《智能座舱背后的秘密:AI赋能测试如何改写驾乘体验》中,我们聊到了“智能座舱”已成为车企争夺用户心智的核心战场、智能座舱功能体验进化、AI赋能座舱测试将突破“场景覆盖、情感量化、角色/场景衍生”技术实现方面的三大困局,并在…...
鸿蒙-试一下属性字符串:除了Span之外,如何在同一个Text组件中展示不同样式的文字
文章目录 前言简介有哪些类型拉出来溜溜Text SpanStyledString其他CustomSpan先看一下构造函数onMeasure(measureInfo: CustomSpanMeasureInfo): CustomSpanMetricsonDraw(context: DrawContext, drawInfo: CustomSpanDrawInfo) 遗留问题 前言 在开发中,经常会遇到…...
今日最新漂亮的早上好图片祝福,最真的牵挂,永远的祝福
1、清晨的一个问候给你一个新的心情、一个祝福带给你新的起点、一个关心带给你一个新的愿望。祝福你心中常有快乐涌现!早安! 2、人过花甲万事休,唯有健康不可丢,荣华富贵皆浮云,逍遥自在渡岁月!时光匆匆&am…...
MySQL 库的操作 -- 增删改查,备份和恢复,系统编码
文章目录 库的操作增删改查数据库的查看和创建查看当前位于哪个数据库中数据库的删除总结显示数据库的创建语句修改数据库 认识系统编码数据库的编码问题查看系统默认的字符集和效验规则校验规则对数据库的影响 数据库的备份和恢复备份还原备份的是一张表 查看数据库的连接情况…...
【c++11】c++11新特性(下)(可变参数模板、default和delete、容器新设定、包装器)
🌟🌟作者主页:ephemerals__ 🌟🌟所属专栏:C 目录 前言 五、可变参数模板 1. 概念及简单定义 2. 包扩展 六、 default和delete 七、容器新设定 1. 新容器 2. 新接口 emplace系列接口 八、函数包…...
fps项目总结:生成武器子弹
文章目录 spawn actor:生成武器固定生成:因为武器的碰撞设为noCollision attach actor to component:将武器附加到骨骼上,成为mesh的子组件对齐到目标:对齐到插槽 子弹阻挡的前提是根组件为碰撞体子弹对碰撞体全是阻挡…...
大模型备案对模型训练语料的要求
昨天接到一位客户的咨询,说他们的模型还在开发阶段,想提前了解一下大模型备案政策中对于模型训练语料有什么具体要求,提前规避一下。客户确实有前瞻性,考虑得比较充分。训练语料在研发阶段至关重要,直接影响模型的性能…...
Ethan独立开发产品日报 | 2025-04-24
1. Peek AI个人财务教练,帮助你做出决策。 Peek的人工智能助手提供主动的跟踪服务——它会分析你的消费习惯,并以细腻而积极的方式帮助你调整这些习惯。没有评判,也没有负担。就像是为你的财务量身定制的Spotify Wrapped,完美贴…...
egg环境搭建
前言 egg.js 是由阿里开源的面向企业级开发的 Node.js 服务端框架,它的底层是由 Koa2 搭建。 Github:https://github.com/eggjs/egg,目前 14.8K Star,egg 很适合做中台。 安装 首先,你要 确保 Node 已经配置环境变量…...
Linux的基础指令
目录 1、Shell及运行原理 2、热键 3、Linux的基础知识 4、Linux的基础指令 4.1 man 4.2 clear&&history&&whoami 4.3 pwd 4.4 ls 4.5 cd 4.6 mkdir&&touch 1. mkdir 2. touch 4.7 rmdir&&rm 1. rmdir 2. rm 4.8 cp&&mv…...
第一部分:git基本操作
目录 1、git初识 1.1、存在的问题 1.2、版本控制器 1.3、git安装 1.3.1、CentOS平台 1.3.2、ubuntu平台 2、git基本操作 2.1、创建仓库 2.2、配置git 3、工作区、暂存区、版本库 4、基本操作 4.1、场景一 4.2、场景二 4.3、修改文件 5、版本回退 6、撤销修改 …...
Kafka和其他组件的整合
Kafka和其他组件的整合 1.Kafka和Flume的整合 需求1:利用flume监控某目录中新生成的文件,将监控到的变更数据发送给kafka,kafka将收到的数据打印到控制台: 在flume/conf下添加.conf文件, vi flume-kafka.conf # 定…...
学习AI必知的20大概念
🎯AI开发者必知的20大概念 🤖 机器学习:基础算法和模型训练。 🧠 深度学习:复杂表示学习。 🌐 神经网络:非线性关系建模。 🗣️ NLP:文本处理和理解。 👁️…...
VRRP与防火墙双机热备实验
目录 实验一:VRRP负载均衡与故障切换 实验拓扑编辑一、实验配置步骤 1. 基础网络配置 2. VRRP双组配置 二、关键验证命令 1. 查看VRRP状态 2. 路由表验证 三、流量分析 正常负载均衡场景: 故障切换验证: 实验二:防火…...
【金仓数据库征文】——选择金仓,选择胜利
目录 第一部分:金仓数据库——开创数据库技术的新时代 1.1 金仓数据库的技术底蕴 1.2 高可用架构与灾备能力 1.3 分布式架构与弹性扩展能力 第二部分:金仓数据库助力行业数字化转型 2.1 电信行业:核心系统国产化替代 2.2 医疗行业&…...
微软官网Win10镜像下载快速获取ISO文件
如何从微软官网轻松下载win10镜像?win10镜像的下载方式主要包括两种: 目录 一:借助官方工具 二:直接微软官网通过浏览器进行下载。 三:实现方法与步骤: 1:利用微软官方提供的MediaCreationT…...
发放优惠券
文章目录 概要整体架构流程技术细节小结 概要 发放优惠券 处于暂停状态,或者待发放状态的优惠券,在优惠券列表中才会出现发放按钮,可以被发放: 需求分析以及接口设计 需要我们选择发放方式,使用期限。 发放方式分…...
【专题刷题】二分查找(二)
📝前言说明: 本专栏主要记录本人的基础算法学习以及LeetCode刷题记录,按专题划分每题主要记录:(1)本人解法 本人屎山代码;(2)优质解法 优质代码;ÿ…...
如何避免IDEA每次打开新项目都重复配置Maven?
每次打开新项目都要重新设置Maven路径?每次导入工程都要手动调整settings.xml?如果你也受够了IDEA这种“健忘”行为,那么这篇文章就是为你准备的!今天我们就来彻底解决这个问题,让IDEA记住你的Maven配置,一…...
【Linux网络编程】应用层协议HTTP(实现一个简单的http服务)
目录 前言 一,HTTP协议 1,认识URL 2,urlencode和urldecode 3,HTTP协议请求与响应格式 二,myhttp服务器端代码的编写 HTTP请求报文示例 HTTP应答报文示例 代码编写 网络通信模块 处理请求和发送应答模块 结…...
深度解析之算法之分治(快排)
44.颜色分类 题目链接 给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums ,原地 对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。 我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。 必须在不使用库内置…...
【金仓数据库征文】-金仓数据库性能调优 “快准稳” 攻略:实战优化,让数据处理飞起来
我的个人主页 我的专栏: 人工智能领域、java-数据结构、Javase、C语言,希望能帮助到大家!!! 点赞👍收藏❤ 目录 一、KingbaseES金仓数据库简介二、快速入门:金仓数据库下载与安装指南三、“快”…...
DPIN河内AI+DePIN峰会:共绘蓝图,加速构建去中心化AI基础设施新生态
近日,一场聚焦前沿科技融合的盛会——AIDePIN峰会在越南河内成功举办。此次峰会由DPIN、QPIN及42DAO等Web3领域的创新项目联合组织,汇聚了众多Web3行业领袖、技术专家与社区成员。峰会于2025年4月19日举行,其核心议题围绕去中心化物理基础设施…...
vscode和git 踩坑
git init经常 在 vscode push错误问题: 正确姿势:先 GitHub 上建仓库 → git clone 拉到本地 → 再用 VSCode 打开编辑 ❌ 不是:VSCode 里 git init → 再去 GitHub 选个仓库绑定 举个对比 操作流程是否推荐后果GitHub 创建仓库 → git clone → 用 VSC…...
C++11介绍
目录 一、C11的两个小点 1.1、decltype 1.2、nullptr 二、列表初始化 2.1、C98传统的{} 2.2、C11中的{} 2.3、C11中的std::initializer_list 三、右值引用和移动语义 3.1、左值和右值 3.2、左值引用和右值引用 3.3、引用延长生命周期 3.4、左值和右值的参数匹配 3…...
AI数字人:繁荣背后的伦理困境与法律迷局(8/10)
摘要:本文深入剖析 AI 数字人从虚拟走向现实的历程,阐述其融合多技术实现从静态到动态交互的跨越,爆发式应用于各领域带来的商业价值与社会影响,同时直面由此引发的伦理法律挑战,包括身份认同、数据隐私、责任归属及权…...
SOLID 原则在单片机环境下的 C 语言实现示例,结合嵌入式开发常见场景进行详细说明
1. 单一职责原则 (SRP) 定义:一个模块(函数/文件)只负责一个功能。 示例:传感器数据采集与处理分离 // SensorAdc.h - 仅负责ADC原始数据采集 typedef struct { uint16_t (*ReadRaw)(void); // 原始数据读取接口 } SensorAdc; // SensorProcessor.h - 仅负责数据处理…...
RT Thread 发生异常时打印输出cpu寄存器信息和栈数据
打印输出发生hardfault时,当前栈十六进制数据和cpu寄存器信息 在发生 HardFault 时,打印当前栈的十六进制数据和 CPU 寄存器信息是非常重要的调试手段。以下是如何实现这一功能的具体步骤和示例代码。 1. 实现 HardFault 处理函数 我们需要在 HardFault 中捕获异常上下文,…...
SQL 函数进行左边自动补位fnPadLeft和FORMAT
目录 1.问题 2.解决 方式1 方式2 3.结果 1.问题 例如在SQL存储过程中,将1 或10 或 100 长度不足的时候,自动补足长度。 例如 1 → 001 10→ 010 100→100 2.解决 方式1 SELECT FORMAT (1, 000) AS FormattedNum; SELECT FORMAT(12, 000) AS Form…...
Unity中数据和资源加密(异或加密,AES加密,MD5加密)
在项目开发中,始终会涉及到的一个问题,就是信息安全,在调用接口,或者加载的资源,都会涉及安全问题,因此就出现了各种各样的加密方式。 常见的也是目前用的最广的加密方式,分别是:DES、3DES、AES、MD5、XOR(异或) 其中DES、3DES、AES、MD5用在数据加密中偏多,特别是…...
C++初窥门径
const关键字 一、const关键字 修饰成员变量 常成员变量:必须通过构造函数的初始化列表进行初始化,且初始化后不可修改。 示例: class Student { private: const int age; // 常成员变量 public: Student(string name, int age) : age(ag…...
Spring知识点总结
目录 1.什么是spring?你对spring的理解? 2.spring的优缺点? 3.解释一下IOC和AOP? 4.IOC和DI的区别? 5.spring中管理对象注入的方式? 6.自动注入的注解有哪些? 声明bean的注解 Bean的生命…...
Oracle_开启归档日志和重做日志
在Oracle中,类似于MySQL的binlog的机制是归档日志(Archive Log)和重做日志(Redo Log) 查询归档日志状态 SELECT log_mode FROM v$database; – 输出示例: – LOG_MODE – ARCHIVELOG (表示已开启) – NO…...
【金仓数据库征文】-数据库界新兴前列者,本篇带你速懂金仓数据库!
最近写课程设计、搞毕设是不是被数据库折腾到崩溃?动不动就报错、数据迁移还超麻烦!今天挖到个宝藏 —— 国产金仓数据库 KingbaseES,操作超简单,还自带 “翻译器” 帮你迁移数据!性能强还稳定,关键完全免费…...
人工智能与机器学习,谁是谁的子集 —— 再谈智能的边界与演进路径
人工智能(Artificial Intelligence, AI)作为当代最具影响力的前沿技术之一,常被大众简化为 “深度学习” 或 “大模型” 等标签。然而,这种简化认知往往掩盖了AI技术内部结构的复杂性与多样性。事实上,AI并非单一方法的…...
Linux进程学习【进程状态】
🌼🌼前言:在操作系统中,进程是最基本的资源管理单位,而操作系统通过精确管理这些进程的状态来确保系统能够高效运行。进程的状态不仅仅是操作系统设计的一部分,它对系统的性能、稳定性以及资源的分配起着至…...
用 ESP32 模拟 Wiegand 刷卡器:开发门禁系统必备的小工具
网罗开发 (小红书、快手、视频号同名) 大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等…...