《Redis高并发优化策略与规范清单:从开发到运维的全流程指南》
Redis高并发优化策略与规范清单:从开发到运维的全流程指南
在互联网应用的后端架构中,Redis凭借其高性能、高并发的特性,成为缓存和数据存储的首选方案。无论是电商抢购、社交平台的点赞计数,还是在线旅游平台的实时数据查询,Redis都在支撑着海量请求的快速处理。然而,随着业务规模的扩大和流量的激增,Redis在高并发场景下也面临诸多挑战,如性能瓶颈、内存溢出、缓存雪崩等。为了确保Redis在高并发环境下稳定高效运行,从开发阶段的规范编写到运维过程的监控与优化,都需要一套完整且严谨的策略与规范。本文将系统地梳理Redis高并发优化的全流程指南,助力开发者和运维人员打造健壮的Redis系统。
一、开发规范:避免踩坑的10条黄金法则
1.1 key设计原则
在Redis中,key的设计直接影响着数据的存储和查询效率,同时也关乎内存的使用情况。合理的key设计遵循两个核心要点:前缀规范和长度控制。
前缀规范采用业务模块:功能:唯一标识
的格式,例如user:profile:123
。这种分层命名方式不仅便于区分不同业务的数据,还能在批量操作时通过通配符快速定位相关key。比如,当需要清理用户模块的所有缓存数据时,使用KEYS user:*
即可筛选出对应key。同时,统一的前缀规范也有助于团队协作开发,避免key命名冲突。
长度控制同样重要,建议将key长度限制在100字节以内。过短的key可能表意不清,而过长的key会增加内存占用和网络传输开销。例如,在一个包含千万级数据的Redis集群中,若每个key平均减少10字节,整体内存占用将显著降低,同时网络传输效率也会提升。
1.2 数据结构选择
Redis提供了丰富的数据结构,如String、Hash、List、Set等,针对不同的业务场景选择合适的数据结构,能有效提升性能。
在计数器场景中,使用INCR
命令比HINCRBY
更高效。INCR
直接对字符串类型的key进行原子自增操作,无需进行复杂的序列化和反序列化;而HINCRBY
操作Hash类型的key,在数据量较大时会产生额外的开销。例如,统计网站的页面访问量,使用INCR page:views:home
即可轻松实现。
对于列表场景,采用LPUSH + LTRIM
组合控制列表长度。LPUSH
向列表左侧添加元素,LTRIM
用于修剪列表,保留指定数量的元素。以消息队列为例,通过LPUSH message_queue new_message
添加消息,再使用LTRIM message_queue 0 999
确保队列长度不超过1000,避免因大list导致的性能问题。
1.3 过期时间设置
过期时间(TTL)的合理设置是Redis开发中的关键环节。禁止设置永不过期的key,因为这可能导致内存持续增长,最终引发内存溢出。对于热点数据,可采用7200+random(0,1800)
秒的动态过期时间,将数据过期时间打散,防止缓存雪崩。
空值缓存也是一种重要的防护手段。当查询数据库未命中数据时,通过SET key null EX 300
将空值缓存到Redis中,设置较短的过期时间。这样在后续相同请求时,可直接从Redis获取空值,避免穿透攻击,减少数据库压力。
二、性能优化:提升QPS的核心手段
2.1 Pipeline批量操作
在高并发场景下,减少网络往返次数是提升性能的重要途径。Pipeline批量操作允许一次性发送多个Redis命令到服务端,服务端处理完所有命令后,一次性返回结果。通过Java代码示例可以清晰看到其实现方式:
List<RedisFuture<?>> futures = redis.pipelined(pipe -> {pipe.get("key1");pipe.get("key2");pipe.get("key3");
});
上述代码中,通过pipelined
方法将多个get
命令打包发送,相比依次执行三个get
命令,大大减少了网络延迟,提升了整体QPS。
2.2 Lua脚本优化
Lua脚本在Redis中具有原子性执行的特性,将多个命令封装为Lua脚本,既能保证操作的原子性,又能减少网络开销。以扣减库存为例,Lua脚本实现如下:
-- 扣减库存脚本
local stock = redis.call('GET', KEYS[1])
if tonumber(stock) > 0 thenredis.call('DECR', KEYS[1])return 1
elsereturn 0
end
通过redis.call
函数调用Redis命令,在脚本中完成库存查询和扣减操作。相比在客户端多次发送命令,这种方式不仅减少了网络传输次数,还避免了并发场景下的库存超卖问题。
2.3 读写分离配置
在主从模式下,开启读写分离能有效分散读流量,提升系统吞吐量。通过在redis.conf
配置文件中设置slave-read-only yes
,将从节点设置为只读模式,使其专门承担读请求。主节点负责写操作和数据同步,读请求则由多个从节点分担,实现读写负载均衡。这种架构设计在高并发读场景下,能显著提升系统性能和响应速度。
三、运维监控:保障稳定性的关键措施
3.1 核心监控指标
运维阶段,实时监控Redis的核心指标是保障系统稳定性的基础。redis_info_keys
用于统计总key数量,当key数量快速增长时,可能预示着内存溢出风险,需及时排查和清理无效key。redis_hit_ratio
即命中率,反映了Redis缓存的有效性,当命中率低于70%时,说明缓存策略需要优化,可能存在大量请求未命中缓存的情况。redis_longest_output_list
监控输出缓冲区长度,若该值持续增长,可能是慢客户端导致,需要及时处理,避免影响Redis性能。
3.2 告警策略设计
合理的告警策略能在问题发生时快速响应,减少故障影响。采用分级告警机制,将告警分为P1和P2两个级别。P1级告警为紧急情况,如内存使用率超过90%、节点失联等,这类问题会直接影响系统可用性,需立即处理;P2级告警为次紧急情况,如命中率低于60%、慢查询数超过100/分钟,需要进一步分析和优化。
同时,为避免告警风暴干扰运维人员,设置告警收敛规则,同一问题在5分钟内仅告警一次,确保运维人员能高效处理真正的故障。
四、大key与热key治理方案
4.1 大key发现与处理
大key会占用大量内存,影响Redis性能,因此需要定期发现和处理。通过redis-cli --bigkeys
命令扫描Redis集群,设置合理的阈值:String类型超过1MB,Hash/List类型字段或元素超过1000个视为大key。对于大hash类型的key,可采用拆分方案,将user:123:info
拆分为user:123:info:basic
、user:123:info:detail
等子hash,降低单个key的大小,提升读写性能。
4.2 热key动态感知
热key是指访问频率极高的key,集中访问可能导致单个节点负载过高。开发热key监控工具,实时统计key的访问频率,自动识别TOP100热key。结合配置中心,将热key列表动态下发到客户端,自动植入JVM缓存。当客户端请求热key时,优先从本地缓存获取数据,减少对Redis的访问压力,实现热key的动态分流。
五、故障应急与容灾预案
5.1 突发流量应对
面对突发流量,可临时调整Redis参数提升性能。例如,将maxmemory-samples
参数从5提升到10,提高LRU(最近最少使用)淘汰算法的准确性,确保在内存紧张时优先淘汰不常用的数据。同时,启用限流机制,通过Sentinel或网关对Redis访问进行限流,设置合理的QPS阈值,避免因流量过大导致缓存雪崩,保障系统稳定运行。
5.2 节点故障处理
主节点故障时,Sentinel会自动将从节点切换为主节点,实现故障转移。运维人员需监控failover耗时,理想情况下应控制在30秒以内,确保服务尽快恢复。针对集群脑裂问题,通过设置min-slaves-to-write 1
和min-slaves-max-lag 10
,要求至少有一个从节点与主节点保持正常数据同步,且延迟不超过10秒,避免脑裂时数据丢失,保证数据一致性。
六、总结:高并发Redis的黄金法则
从开发到运维,Redis高并发优化是一个系统性工程。在设计层面,需遵循数据分片、热key拆分、多级缓存的原则,合理规划数据存储和访问方式;开发过程中,严格执行开发规范,包括合理设置TTL、选择高效数据结构、避免大key等;运维阶段,通过实时监控、定期巡检和完善的容灾预案,保障Redis系统的稳定性和可用性。
通过本文梳理的全流程优化策略与规范清单,开发者和运维人员能够全面掌握Redis高并发优化的核心要点,在实际项目中灵活运用,打造出高效、稳定的Redis系统,为业务发展提供坚实的技术支撑。随着技术的不断演进,Redis优化也将持续迭代,未来还需不断探索新的方法和工具,迎接更高并发场景的挑战。
相关文章:
《Redis高并发优化策略与规范清单:从开发到运维的全流程指南》
Redis高并发优化策略与规范清单:从开发到运维的全流程指南 在互联网应用的后端架构中,Redis凭借其高性能、高并发的特性,成为缓存和数据存储的首选方案。无论是电商抢购、社交平台的点赞计数,还是在线旅游平台的实时数据查询&…...
Linux基本指令篇 —— man指令
man命令是Linux系统中最重要的命令之一,它是"manual"(手册)的缩写,用于查看Linux系统中命令、函数、配置文件等的详细说明文档。man命令是Linux系统管理员和开发者的必备工具,熟练掌握man命令可以大大提高工…...
Spring Boot使用MCP服务器
1、JDK版本17 2、pom文件 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apac…...
学习Linux进程冻结技术
原文:蜗窝科技Linux进程冻结技术 功耗中经常需要用到,但是linux这块了解甚少,看到这个文章还蛮适合我阅读的 1 什么是进程冻结 进程冻结技术(freezing of tasks)是指在系统hibernate或者suspend的时候,将…...
Docker基本概念——AI教你学Docker
1.1 Docker 概念详解 1. Docker 是什么? Docker 是一个开源的应用容器引擎,它让开发者可以将应用及其依赖打包到一个可移植的容器(Container)中,并在任何支持 Docker 的 Linux、Windows 或 macOS 系统上运行。这样做…...
第十六届蓝桥杯C/C++程序设计研究生组国赛 国二
应该是最后一次参加蓝桥杯比赛了,很遗憾,还是没有拿到国一。 大二第一次参加蓝桥杯,印象最深刻的是居然不知道1s是1000ms,花了很多时间在这题,后面节奏都乱了,抗压能力也不行,身体也不适。最后…...
Python 数据分析与可视化 Day 5 - 数据可视化入门(Matplotlib Seaborn)
🎯 今日目标 掌握 Matplotlib 的基本绘图方法(折线图、柱状图、饼图)掌握 Seaborn 的高级绘图方法(分类图、分布图、箱线图)熟悉图像美化(标题、标签、颜色、风格)完成一组学生成绩数据的可视化…...
WebRTC(八):SDP
SDP 概念 SDP 是一种描述多媒体通信会话的文本格式(基于 MIME,RFC 4566)。本身 不传输数据,仅用于在会话建立阶段传递信息。常与 SIP(VoIP)、RTSP、WebRTC 等协议配合使用。 用途 描述媒体类型…...
《哈希表》K倍区间(解题报告)
文章目录 零、题目描述一、算法概述二、算法思路三、代码实现四、算法解释五、复杂度分析 零、题目描述 题目链接:K倍区间 一、算法概述 计算子数组和能被k整除的子数组数量的算法。通过前缀和与哈希表的结合,高效地统计满足条件的子数组。 需要注…...
牛津大学开源视频中的开放世界目标计数!
视频中的开放世界目标计数 GitHub PaPer Niki Amini-Naieni nikianrobots.ox.ac.uk Andrew Zisserman azrobots.ox.ac.uk 视觉几何组(VGG),牛津大学,英国 图 1:视频中的目标计数:给定顶行的视频&#…...
1.2、CAN总线帧格式
1、帧类型 2、帧类型介绍 (1)数据帧 扩展格式是为了扩展ID,ID号每4位一个字节(11位最大ID号为0x7FF) (2)遥控帧 遥控帧由于没有Data,所以DLC可能没有意义,可给任意值&am…...
DeepSeek今天喝什么随机奶茶推荐器
用DeepSeek生成了一个随机奶茶推荐器-今天喝什么,效果非常棒!UI界面美观。 提示词prompt如下 用html5帮我生成一个今天喝什么的网页 点击按钮随机生成奶茶品牌等,要包括中国常见的知名的奶茶品牌 如果不满意还可以随机再次生成 ui界面要好看 …...
词编码模型怎么进行训练的,输出输入是什么,标签是什么
词编码模型怎么进行训练的,输出输入是什么,标签是什么 词编码模型的训练本质是通过数据驱动的方式,将离散的文本符号映射为连续的语义向量。 一、训练机制:从符号到向量的映射逻辑 1. 核心目标 将单词/子词(Token)映射为低维向量,使语义相关的词在向量空间中距离更近…...
LSTM、GRU 与 Transformer网络模型参数计算
参数计算公式对比 模型类型参数计算公式关键组成部分LSTM4 (embed_dim hidden_size hidden_size hidden_size)4个门控结构GRU3 (embed_dim hidden_size hidden_size hidden_size)3个门控结构Transformer (Encoder)12 embed_dim 9 embed_dim ff_dim 14 embed_dim…...
nnv开源神经网络验证软件工具
一、软件介绍 文末提供程序和源码下载 用于神经网络验证的 Matlab 工具箱,该工具箱实现了可访问性方法,用于分析自主信息物理系统 (CPS) 领域中带有神经网络控制器的神经网络和控制系统。 二、相关工具和软件 该工具箱利用神经…...
SQLite3 在嵌入式系统中的应用指南
SQLite3 在嵌入式系统中的应用指南 一、嵌入式系统中 SQLite3 的优势 SQLite3 是嵌入式系统的理想数据库解决方案,具有以下核心优势: 特性嵌入式系统价值典型指标轻量级适合资源受限环境库大小:500-700KB零配置无需数据库管理员开箱即用无…...
原生微信小程序网络请求与上传接口封装实战指南
本文基于微信小程序原生 API,封装 request 和 uploadFile 接口,最终实现统一请求管理、请求拦截、错误处理等能力。 📦 一、为什么要封装网络请求? 微信小程序提供了 wx.request 和 wx.uploadFile 原生 API,但直接使用…...
电路图识图基础知识-塔式起重机控制电路识图与操作要点(三十五)
引言: 塔式起重机作为建筑施工中不可或缺的大型起重运输机械设备,其控制电路的识图与操作对于确保施工安全和效率至关重要。本文将详细介绍塔式起重机的控制电路识图,帮助操作人员更好地理解和掌握其工作原理。 一、塔式起重机概述 塔式起重…...
基于SpringBoot + Vue 的网上拍卖系统
基于springbootvue的在线拍卖系统| Java | vue | 配万字文档 | springboot001 〔运行环境〕 Java版本:jdk1.8 node版本:13.x python版本:2.7 IDE类型:idea或exlipse 数据库:MySQL(5.x或8.x版本都…...
用 EXCEL/WPS 实现聚类分析:赋能智能客服场景的最佳实践
聚类分析作为无监督学习的核心技术,能在客服数据中发现隐藏的用户群体或问题模式。尽管 Excel/WPS 并非专业统计软件,但巧妙利用其内置功能,也能实现基础的聚类分析,为中小型客服团队提供快速洞察。以下介绍具体方法及智能客服场景…...
利用mold加快rust程序构建
我用rust的cargo build命令编译polars-cli时,用时达到14分钟,如下所示。 Finished dev profile [unoptimized debuginfo] target(s) in 14m 19s,通过核对时间戳,发觉其中最后一步生成可执行文件花了6分钟。 于是向DeepSeek请教&a…...
leetcode543-二叉树的直径
leetcode 543 思路 路径长度计算:任意两个节点之间的路径长度,等于它们的最低公共祖先到它们各自的深度之和递归遍历:通过后序遍历(左右根)计算每个节点的左右子树深度,并更新全局最大直径深度与直径的关…...
(三)yolov5——模型训练
一、准备数据 先准备一个MP4的视频 1.测试一帧 使用opencv来提取每一个视频的帧 先使用以下代码查看一帧的内容,是否符合预期 import cv2 import matplotlib.pyplot as plt# 打开视频文件 video cv2.VideoCapture("111.mp4") # 读取一帧 ret, frame…...
STM32对接霍尔传感器
STM32对接霍尔传感器的技术解析与应用实现,结合测速原理、硬件设计、代码实现及进阶应用,涵盖从基础到实战的全流程指南,可以应用到金属检测等功能。 ⚙️ 一、霍尔传感器基础 工作原理 霍尔传感器基于霍尔效应,当磁铁靠近时输出电平变化(常开型无磁铁时输出高电平,靠近时…...
SpringCloud系列(32)--使用Hystrix进行全局服务降级
前言:在上一节中我们使用Hystrix进行了服务降级,但是要在每个方法上面配置HystrixCommand才能实现服务降级,如果需要进行服务降级的方法多了,HystrixCommand也就得配置很多遍,所以本节内容则是使用Hystrix进行了全局服…...
Origin绘制三Y轴柱状图、点线图、柱状点线图
三Y轴柱状图是一种高级数据可视化形式,它通过三个独立的纵轴在同一个图表中展示不同量纲或量级的数据系列。其主要用于揭示不同量级指标间的关联性(例如高销售额是否伴随高利润率)。 当数据满足以下条件时,即可绘制三Y轴图&#x…...
通信网络编程3.0——JAVA
主要添加了私聊功能 1服务器类定义与成员变量 public class ChatServer {int port 6666;// 定义服务器端口号为 6666ServerSocket ss;// 定义一个 ServerSocket 对象用于监听客户端连接//List<Socket> clientSockets new ArrayList<>();// 定义一个列表用于存储…...
4-深度学习网络层
深度学习模型 Embedding层 Embedding矩阵是可训练的参数,一般会在模型构建时随机初始化 也可以使用预训练的词向量来做初始化,此时也可以选择不训练Embedding层中的参数 输入的整数序列可以有重复,但取值不能超过Embedding矩阵的列数 核心…...
【LeetCode】用双指针解决移除元素问题、合并两个有序数组求解
🔥个人主页:艾莉丝努力练剑 ❄专栏传送门:《C语言》、《数据结构与算法》、C语言刷题12天IO强训 🍉学习方向:C/C方向 ⭐️人生格言:为天地立心,为生民立命,为往圣继绝学,…...
车载诊断架构协议篇 --- OBDonUDS和ZEVonUDS
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 做到欲望极简,了解自己的真实欲望,不受外在潮流的影响,不盲从&#x…...
医学 Agent:自带医学深度调研 deep research,优化治疗策略+药物参考
医学 Agent:自带医学深度调研deep research,优化治疗策略药物参考 第一版代码输出结果,居然连不上网运行结果梳理 第二版结果测试 第一版代码 医疗顾问AI系统 - 基于Qwen API 的智能医疗助手 最终目标:构建一个能够查询疾病治疗方…...
硬件工程师笔试面试高频考点汇总——(2025版)
目录 1 电子器件部分 1.1 电阻 1.1.1 电阻选型时一般从哪几个方面进行考虑? 1.1.2 上拉下拉电阻的作用 1.1.3 PTC热敏电阻作为电源电路保险丝的工作原理 1.1.4 如果阻抗不匹配,有哪些后果 1.1.5 电阻、电容和电感0402、0603和0805封装的含义 1.1.6 电阻、电…...
春秋云镜【CVE-2017-18349】fastjson wp
知识点 fastjson反序列化 将json转为java对象的过程 漏洞存在版本 Fastjson<1.2.24 漏洞原理 fastjson引入的autotype功能,本来是为了区分同名同元素但是不同类型的对象序列化后内容一致无法还原的问题,但是这一操作允许了json数据中通过type来指定对…...
网络编程:八股文
一.Reactor网络模型 ------------------- | 应用主线程 | -------------------|v ------------------- | Reactor | | (事件分发器) | -------------------|v ------------------- | 事件多路分发器 | <--- epoll/poll/select -----------------…...
设计模式精讲 Day 11:享元模式(Flyweight Pattern)
【设计模式精讲 Day 11】享元模式(Flyweight Pattern) 文章内容 在软件开发过程中,我们常常需要处理大量相似对象的创建和管理问题。如果这些对象之间存在大量的重复信息,直接创建每一个对象会导致内存占用过高、系统性能下降。享…...
常用终端命令(Linux/macOS/bash 通用)分类速查表
文件与目录操作 命令作用说明pwd显示当前路径ls列出当前目录内容ls -l以列表形式显示文件详细信息ls -a显示所有文件(包括隐藏文件)cd <目录名>进入指定目录cd ..返回上一级目录cd ~回到用户主目录mkdir <目录名>创建目录mkdir -p a/b/c创建…...
Robyn高性能Web框架系列04:事件、中间件与错误处理
请求-响应过程 应用启动、关闭事件1、启动事件(Startup Events)2、关闭事件(Shutdown Events) 中间件1、前置中间件(BeforeRequest)2、后置中间件(AfterRequest)3、示例:…...
深入理解JavaScript设计模式之迭代器模式
文章目录 深入理解JavaScript设计模式之迭代器模式定义官方翻译白话翻译 实现jQuery中的each迭代器实现数组迭代器迭代器实现创建Dom元素 内部迭代器和外部迭代器内部迭代器外部迭代器 迭代类数组对象和字面量对象倒序迭代器中止迭代器迭代器的应用举例音乐播放器案例待输出更新…...
【项目管理】项目管理资料文档模板(ZIP,PPT,WORD)
项目交付文档 01项目详细调研计划编写规范V1.0.doc 03项目详细调研报告编写规范V1.0.doc 07软件需求规格说明书评审规范V1.0.doc 10.软件需求规格说明.doc 产品检查单,xls 工程评审.zip 软件标准过程集.zip 系统测试管理规程.docx 四)项目管理计划.doc 项目管理系统实施项目管理…...
DeepSeek中的提示库及其用法示例
《DEEPSEEK原生应用与智能体开发实践 图书》【摘要 书评 试读】- 京东图书 为了深入探索DeepSeek提示词样例的丰富内涵,充分挖掘其背后潜藏的无限可能,同时致力于为用户打造更为卓越、便捷且高效的使用体验,DeepSeek官网的API文档匠心独运地…...
292. Nim 游戏
292. Nim 游戏 - 力扣(LeetCode) 想法 枚举问题: n 1 ~ 3 ,由于我先手,我可以直接拿走全部的石头,所以我赢n 4,由于我先手,我拿掉 1 - 3 块石头 ,剩下的可能就是 1 -…...
STM32 串口通信②:蓝牙模块HC-05控制单片机
一 前言 上一篇我们已经成功实现单片机和电脑的连接,接下来,我们学习一个有趣的板块,HC-05蓝牙模块,这个蓝牙模块,我们就要建立手机和单片机的通讯啦,还是比较有趣的一个过程,大家可以跟着多操作…...
艾立泰数字化重塑汽车零部件包装租赁行业
在汽车零部件包装租赁行业,资产利用率低、流转效率差、运输成本高等痛点长期困扰企业。艾立泰科技通过数字化解决方案,成为该行业降本增效的关键合作伙伴,助力企业实现从传统管理模式向智能化的跃迁。 精准库存管理:告别“盲人摸…...
Windows电脑数据恢复终极指南:从原理到实战
Windows电脑数据恢复终极指南:从原理到实战 数据丢失是每个电脑用户都可能遭遇的噩梦。本文将为您全面解析Windows平台下的数据恢复技术,从基础原理到高级技巧,帮助您在文件误删、格式化、系统崩溃等情况下找回宝贵数据。 一、数据恢复基础…...
进入python虚拟环境的方法
首先,切换到虚拟环境所在的目录(即包含venv文件夹的目录): Cmd cd D:\phd\phd1spring\July\pythonstduy\projecton 然后,激活虚拟环境: Cmd .\venv\Scripts\activate 如果上述方法不行,还可…...
大数据时代UI前端的变革:从静态展示到动态交互
hello宝子们...我们是艾斯视觉擅长ui设计、前端开发、数字孪生、大数据、三维建模、三维动画10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 在大数据时代,信息以前所未有的速度和规模增长。这种数据环境的变化,深…...
海拔案例分享-门店业绩管理小程序
在各大电商平台和直播带货如火如荼来的当下,各行各业的门店都在积极寻求创新的管理方式,以提升业绩、优化运营。长沙的一家策划运营公司,敏锐地捕捉到这一市场需求,他们见过太多门店老板对着Excel表格叹气:美容店算错提…...
Python中的数据可视化:使用Matplotlib绘制图表
数据可视化是将复杂数据集转换为图形或图像表示的过程,旨在简化信息的解释和传达。Python作为一种多功能编程语言,提供了多种强大的库来实现这一目标,其中最受欢迎和广泛使用的是Matplotlib。 首先,我们需要确保已经安装了必要的…...
【VUE】1.准备工作
一、环境准备(本机仅需一次) 安装 Node.js(推荐 LTS 版本,包含 npm) 打开 VSCode,安装插件(推荐): Vetur 或 Volar(用于 Vue 支持) ESLint / Pr…...
Linux下的版本控制器Git(15)
文章目录 如何理解版本控制(9-0.00.00)Git 的理解Git 的历史具体操作和用法补充细节 简介:那个对Git的理解,是我用自己的话语结合故事进行阐述,可能理解的不到位,有些错误还请多多包含!说句实话…...