EF Core缓存技术革命:EFCache如何让数据库负载下降70%?

第一章:EF Core缓存技术革命:EFCache如何让数据库负载下降70%?

在现代高并发应用中,数据库往往成为系统性能的瓶颈。EFCache作为Entity Framework Core的扩展组件,通过引入高效的查询结果缓存机制,显著减少了对数据库的重复访问,实测可使数据库负载降低高达70%。

缓存工作原理

EFCache拦截EF Core生成的SQL查询,并基于查询语句及其参数生成唯一键。若缓存中已存在该键对应的数据,则直接返回结果,避免执行数据库往返。

快速集成步骤

  1. 安装NuGet包:
    dotnet add package EFCache
  2. Startup.csProgram.cs中配置服务:
// 启用EFCache服务
services.AddEntityFrameworkCache(options =>
{
    options.UseInMemoryProvider(); // 使用内存缓存
    options.ExpirationMode = ExpirationMode.Sliding; // 滑动过期
    options.Duration = TimeSpan.FromMinutes(10); // 缓存10分钟
});

适用场景对比

场景是否适合使用EFCache说明
高频读取静态数据如国家、城市列表,缓存命中率高
实时性要求极高的数据如交易流水,需避免脏读
graph LR A[应用发起查询] --> B{缓存是否存在?} B -- 是 --> C[返回缓存数据] B -- 否 --> D[执行数据库查询] D --> E[写入缓存] E --> F[返回结果]

第二章:EFCache核心机制解析

2.1 缓存工作原理与查询拦截技术

缓存的核心在于将高频访问的数据存储在快速访问的介质中,以降低数据库负载并提升响应速度。当应用发起数据查询时,系统首先检查缓存中是否存在对应键值,若命中则直接返回结果,否则回源数据库并回填缓存。
查询拦截机制
通过AOP或代理模式在SQL执行前进行拦截,解析查询语义并生成缓存键。例如,在MyBatis中可通过实现Interceptor接口完成:

@Intercepts({@Signature(type = Statement.class, method = "execute", args = {String.class})})
public class CacheInterceptor implements Interceptor {
    public Object intercept(Invocation invocation) throws Throwable {
        String sql = (String) invocation.getArgs()[0];
        String cacheKey = DigestUtils.md5Hex(sql);
        Object result = CacheManager.get(cacheKey);
        if (result != null) return result;
        result = invocation.proceed();
        CacheManager.put(cacheKey, result);
        return result;
    }
}
该拦截器在SQL执行前计算其MD5作为缓存键,若缓存存在则跳过数据库查询。参数invocation封装了原始方法调用,通过proceed()触发真实执行。
缓存更新策略
为避免脏数据,常采用写穿透(Write-Through)或失效策略。常见做法是在更新数据库后使相关缓存失效:
  • 读操作:先查缓存,未命中则查数据库并写入缓存
  • 写操作:更新数据库后删除对应缓存键

2.2 基于内存与分布式缓存的集成策略

在高并发系统中,单一内存缓存难以应对数据共享与扩展性需求,需结合本地内存与分布式缓存构建多级缓存架构。通过将热点数据存储于本地内存,降低访问延迟,同时利用分布式缓存(如Redis)实现数据一致性。
缓存层级设计
典型的两级缓存结构包括:
  • Level 1:基于JVM堆内存或Caffeine实现,访问延迟低
  • Level 2:Redis集群,支持跨节点数据共享与持久化
数据同步机制
为避免缓存不一致,采用“写穿透”策略同步更新两级缓存:

// 更新数据库与缓存
public void updateProduct(Product product) {
    repository.save(product);
    localCache.put(product.getId(), product);     // 更新本地缓存
    redisTemplate.opsForValue().set("prod:" + product.getId(), product); // 更新Redis
}
上述代码确保数据变更时,双层缓存同步刷新,保障数据一致性。localCache适用于高频读取场景,Redis支撑横向扩展能力。

2.3 缓存键生成与哈希算法优化

在高并发系统中,缓存键的合理生成直接影响命中率与数据隔离性。为避免键冲突并提升分布均匀性,需结合业务维度设计唯一标识。
缓存键构造策略
推荐使用分层结构组合关键字段,例如:`{namespace}:{userId}:{resourceType}:{id}`。该方式增强可读性,同时便于调试与缓存清理。
哈希算法选型对比
算法速度分布均匀性适用场景
MurmurHash优秀通用缓存分片
MD5中等良好长键压缩
代码实现示例

// GenerateCacheKey 使用MurmurHash3生成固定长度哈希值
func GenerateCacheKey(parts ...string) string {
    key := strings.Join(parts, ":")
    hash := murmur3.Sum64([]byte(key))
    return fmt.Sprintf("%x", hash) // 转为16进制字符串
}
上述函数将多个业务字段拼接后通过MurmurHash3计算,确保高散列性和低碰撞率,适用于分布式缓存环境中的键归一化处理。

2.4 查询结果序列化与存储性能分析

在高并发数据查询场景中,序列化效率直接影响存储写入性能。采用高效的序列化协议可显著降低 I/O 延迟。
常用序列化格式对比
  • JSON:可读性强,但体积大,解析慢;
  • Protobuf:二进制编码,压缩率高,适合大规模数据传输;
  • Avro:支持模式演化,适用于长期存储。
性能测试代码示例

// 使用 Protobuf 序列化查询结果
func SerializeResult(result *QueryResult) ([]byte, error) {
    return proto.Marshal(result) // 高效二进制编码,减少存储空间
}
上述函数将查询结果对象序列化为字节流,proto.Marshal 在时间和空间开销上均优于 JSON 编码。
写入性能对比表
格式序列化耗时(μs)输出大小(KB)
JSON15048
Protobuf6522

2.5 缓存失效策略与数据一致性保障

在高并发系统中,缓存失效策略直接影响数据一致性。常见的失效方式包括定时过期(TTL)和主动失效。其中,主动失效在数据更新时同步清除缓存,能更有效地保障一致性。
缓存更新模式对比
  • Write-Through:先更新缓存,再由缓存层写入数据库,保证缓存与数据库一致;
  • Write-Behind:异步写入数据库,性能高但存在数据丢失风险;
  • Write-Around:直接写数据库,不更新缓存,适用于写多读少场景。
代码示例:Redis 主动失效实现
func UpdateUser(db *sql.DB, redisClient *redis.Client, userID int, name string) error {
    // 更新数据库
    _, err := db.Exec("UPDATE users SET name = ? WHERE id = ?", name, userID)
    if err != nil {
        return err
    }
    // 主动清除缓存
    redisClient.Del(context.Background(), fmt.Sprintf("user:%d", userID))
    return nil
}
该函数在更新数据库后立即删除 Redis 中对应 key,避免脏数据。参数 userID 用于定位缓存键,确保精准失效。
数据同步机制
使用消息队列(如 Kafka)可解耦缓存与数据库操作,通过发布订阅模式实现跨服务缓存同步,提升系统扩展性。

第三章:EFCache实战配置指南

3.1 项目中集成EFCache的完整步骤

安装与引用依赖
首先通过 NuGet 安装 EFCache 包。在包管理器控制台执行以下命令:
Install-Package EntityFramework.Cache
该命令将引入 EF Caching 模块及其依赖项,包括对内存缓存机制的支持。
配置缓存提供程序
在应用程序启动时注册缓存模块。以使用内存缓存为例:
DbConfiguration.SetConfiguration(new CacheConfiguration());
其中 CacheConfiguration 继承自 DbConfiguration,用于注入缓存拦截器,自动捕获查询并缓存结果。
启用缓存策略
通过如下方式为查询启用缓存:
  • 调用 .Cache() 方法显式标记查询
  • 设置默认过期策略,如滑动过期时间
  • 结合 MemoryCache 管理缓存生命周期

3.2 不同缓存提供者(Memory、Redis)的配置实践

内存缓存配置
内存缓存适用于单机部署场景,具有低延迟优势。在 Go 应用中可使用 sync.Map 实现线程安全的本地缓存:

var cache = sync.Map{}

func Set(key string, value interface{}) {
    cache.Store(key, value)
}

func Get(key string) (interface{}, bool) {
    return cache.Load(key)
}
该实现无需外部依赖,StoreLoad 方法提供原子性操作,适合存储生命周期短的会话数据。
Redis 缓存集成
分布式系统推荐使用 Redis 作为统一缓存层。通过 go-redis 客户端连接实例:

rdb := redis.NewClient(&redis.Options{
    Addr:     "localhost:6379",
    Password: "",
    DB:       0,
})
Addr 指定服务地址,DB 选择逻辑数据库,支持设置 TTL 实现自动过期。
选型对比
特性MemoryRedis
性能极高
持久化支持
扩展性良好

3.3 日志调试与缓存命中率监控方法

精细化日志调试策略
在高并发系统中,启用分级日志记录可快速定位问题。通过设置日志级别为 DEBUG 捕获详细执行流程:

log.SetLevel(log.DebugLevel)
log.Debug("Cache lookup", "key", key, "hit", found)
该代码片段启用 debug 级别日志,输出缓存查询的键值及命中状态,便于追踪访问模式。
缓存命中率监控指标
命中率是评估缓存有效性的核心指标,可通过以下公式实时计算:
  1. 记录总请求数(totalRequests)
  2. 记录命中数(hits)
  3. 命中率 = hits / totalRequests
使用 Prometheus 暴露指标:

hitRate.WithLabelValues("cache").Set(float64(hits) / float64(totalRequests))
该指标可接入 Grafana 实时可视化,及时发现缓存失效或穿透问题。

第四章:典型应用场景与性能优化

4.1 高频读取场景下的缓存加速实践

在高频读取的业务场景中,数据库往往成为性能瓶颈。引入缓存层可显著降低后端压力,提升响应速度。常见策略是使用 Redis 作为一级缓存,配合本地缓存(如 Caffeine)构建多级缓存架构。
缓存更新策略
采用“Cache Aside”模式,读请求优先从缓存获取数据,未命中则回源数据库并写入缓存。写操作时先更新数据库,再失效缓存,确保最终一致性。
// Go 示例:缓存读取逻辑
func GetUser(id int) (*User, error) {
    cacheKey := fmt.Sprintf("user:%d", id)
    data, err := redis.Get(cacheKey)
    if err == nil {
        return parseUser(data), nil // 缓存命中
    }
    user, dbErr := db.Query("SELECT * FROM users WHERE id = ?", id)
    if dbErr != nil {
        return nil, dbErr
    }
    redis.Setex(cacheKey, 300, serialize(user)) // 异步写回
    return user, nil
}
该代码实现标准的缓存旁路模式,设置5分钟过期时间防止雪崩。
性能对比
方案平均延迟(ms)QPS
直连数据库482100
单级Redis812500
多级缓存328000

4.2 多表关联查询的缓存效率提升方案

在复杂业务场景中,多表关联查询常成为性能瓶颈。传统方式将完整结果集缓存,存在数据冗余与更新滞后问题。更优策略是采用“分层缓存 + 主键映射”机制。
缓存结构设计
将关联表拆解为独立缓存单元,通过主键建立映射关系。例如用户订单查询可拆分为用户缓存、订单缓存和映射索引。
表名缓存键过期策略
usersuser:{id}30分钟
ordersorder:{id}10分钟
代码实现示例
// 查询订单及关联用户信息
func GetOrderWithUser(orderID int) (*OrderDetail, error) {
    var detail OrderDetail
    orderKey := fmt.Sprintf("order:%d", orderID)
    
    // 先查订单缓存
    if err := cache.Get(orderKey, &detail.Order); err != nil {
        // 缓存未命中,回源数据库
        order, err := db.QueryOrder(orderID)
        if err != nil { return nil, err }
        cache.Set(orderKey, order, 600)
        detail.Order = order
    }
    
    // 异步加载用户信息
    userKey := fmt.Sprintf("user:%d", detail.Order.UserID)
    cache.GetOrFetch(userKey, &detail.User, db.QueryUserByID, 1800)
    
    return &detail, nil
}
该函数首先尝试从缓存获取订单数据,若未命中则查询数据库并写入缓存;用户信息通过懒加载方式获取,降低单次请求延迟。

4.3 缓存穿透与雪崩问题的应对策略

缓存穿透指查询不存在的数据,导致请求直达数据库。常见对策是使用布隆过滤器预先判断键是否存在。
布隆过滤器示例代码
func NewBloomFilter(size uint, hashCount uint) *BloomFilter {
    return &BloomFilter{
        bitSet:    make([]bool, size),
        size:      size,
        hashCount: hashCount,
    }
}
该代码初始化一个布隆过滤器,size 表示位数组大小,hashCount 为哈希函数数量,用于控制误判率。
缓存雪崩的解决方案
当大量缓存同时失效,可能引发雪崩。可通过以下方式缓解:
  • 设置差异化过期时间,避免集中失效
  • 启用缓存预热机制,在服务启动时加载热点数据
  • 采用集群部署提升高可用性

4.4 结合查询过滤器实现智能缓存

在高并发系统中,缓存的有效性往往受限于数据的动态过滤条件。通过将查询过滤器与缓存策略结合,可实现更精细化的数据命中机制。
缓存键的动态构建
基于查询参数生成唯一缓存键,确保不同过滤条件对应独立缓存。例如:
func GenerateCacheKey(filter Filter) string {
    hash := sha256.New()
    hash.Write([]byte(filter.UserID))
    hash.Write([]byte(filter.StartDate))
    hash.Write([]byte(filter.Status))
    return hex.EncodeToString(hash.Sum(nil))
}
该函数将用户ID、时间范围和状态拼接后哈希,生成全局唯一的缓存键,避免不同查询间的数据污染。
缓存策略优化
使用LRU(最近最少使用)算法管理缓存生命周期,并结合TTL控制数据新鲜度。以下为常见配置场景:
过滤维度缓存有效期最大条目数
用户ID + 状态5分钟10,000
全局统计30分钟100

第五章:未来展望:EF Core缓存生态的发展方向

智能化缓存策略集成
未来的 EF Core 缓存生态将趋向于引入机器学习模型,动态分析查询模式以自动选择最优缓存策略。例如,基于访问频率和数据变更率,系统可自动将高频读取、低频更新的实体加入内存缓存,而将冷数据移出。
分布式缓存的无缝扩展
随着微服务架构普及,EF Core 将更深度整合 Redis Cluster 和 Azure Cache for Redis。开发者可通过配置实现分片与故障转移:

services.AddDbContextPool<AppDbContext>(options =>
    options.UseSqlServer(connectionString)
           .UseQueryTrackingBehavior(QueryTrackingBehavior.NoTracking)
           .UseRedisCache(redisConnectionString, 
               new[] { "Product", "Category" }, 
               TimeSpan.FromMinutes(10)));
  • 支持多级缓存层级(L1/L2)自动同步
  • 提供缓存穿透保护机制,如布隆过滤器预检
  • 集成 OpenTelemetry 实现缓存命中率可视化监控
编译时缓存元数据生成
借助 Source Generators,EF Core 可在编译期预生成实体缓存键结构,减少运行时反射开销。例如:

[GenerateEntityCacheKey]
public class Product
{
    public int Id { get; set; }
    public string Name { get; set; }
}
// 编译后自动生成:ProductCacheKeyBuilder.Build(entity)
特性当前状态未来方向
缓存一致性手动失效基于 CDC 的自动同步
跨上下文共享有限支持统一缓存网关
查询请求 → 检查本地缓存 → 命中则返回 → 未命中 → 查找分布式缓存 → 更新本地缓存 → 返回结果
已经博主授权,源码转载自 https://pan.quark.cn/s/fb533687a163 《C++经典代码大全》是一部专门针对C++入门者的重要参考资料,其核心目标在于提供易于理解的C++编程范例,旨在协助新学者迅速领会C++语言的关键概念与技术要点。此压缩文件所包含的信息或许涵盖了从基础到高级的各类C++编程技巧,涉及面向对象编程中的类与对象、函数的应用、程序流程控制、数据结构设计、模板技术以及异常管理等多个关键领域。 1. **基础语法** - 变量声明与初始化:掌握如何声明并初始化不同数据类型的变量,例如整型(int)、浮点型(float)、字符型(char)等。 - 基本输入输出:学习运用`std::cin`和`std::cout`执行标准数据输入与输出操作。 - 控制流语句:熟练运用条件语句(if、if-else、switch-case)以及循环语句(for、while、do-while)来控制程序流程。 2. **类与对象** - 类的定义:学会如何构建类,包含其成员变量与成员函数的设定。 - 对象的创建与使用:掌握如何实例化对象,并经由对象访问类的成员函数。 - 封装:理解封装的理念,并学习使用private和public访问修饰符来保护数据。 - 构造函数与析构函数:掌握如何为类定义自定义的构造过程与析构过程。 3. **函数** - 函数的定义与调用:理解函数的功能与作用,以及如何进行函数的定义和调用。 - 函数参数:精通不同类型的参数传递方法,包括值传递和引用传递。 - 函数重载:学习在同一作用域内定义多个具有相同名称但参数列表不同的函数。 - 函数指针:了解函数指针的运用方法,及其在回调函数和模板中的应用场景。 4. **数组与字符串** -...
内容概要:本文研究了一种计及自适应预测修正的微电网模型预测控制(MPC)优化调度方法,并提供了Matlab代码实现。该方法针对微电网中风电出力等可再生能源的强不确定性,引入自适应预测修正机制,动态调整预测模型以提升短期功率预测精度,从而增强调度决策的准确性与系统运行的鲁棒性。研究构建了完整的MPC滚动优化框架,涵盖预测模型建立、多时间尺度优化求解、实时反馈校正等关键环节,实现了系统运行成本最小化、能源高效利用与功率平衡的多重目标。所提方法有效应对了负荷波动与新能源出力随机性带来的调度挑战,提升了微电网能量管理系统的智能化水平。; 适合人群:具备电力系统、自动化、控制理论或相关领域基础知识的研究生、科研人员及工程技术人员,尤其适合从事微电网优化、可再生能源集成、模型预测控制研究的专业人士,熟悉Matlab编程与优化算法者更佳。; 使用场景及目标:①应用于高比例可再生能源接入的微电网能量管理系统,提升调度方案的实时性与鲁棒性;②为不确定性环境下电力系统动态优化控制策略的研究提供仿真验证平台;③支持学术论文复现、科研课题攻关及实际工程项目的前期技术验证与方案预研。; 阅读建议:建议结合Matlab代码逐模块分析算法实现细节,重点关注预测模型构建与反馈修正机制的设计逻辑,通过调整风电出力、负荷需求等场景参数进行仿真实验,深入理解MPC在微电网调度中的滚动优化特性与自适应修正能力。
代码下载链接: https://pan.quark.cn/s/a4b39357ea24 在信息技术领域中,字符编码扮演着处理文本数据的核心角色。本文着重研究在微控制器系统中,运用C语言如何将UTF-8编码格式转换为GBK编码格式,旨在处理串口通信、TF卡存储或LCD显示屏上可能出现的中文显示错误问题。我们将详细剖析UTF-8与GBK编码的运作机制,并研究基于Keil开发平台的C语言实现流程。 UTF-8是一种被广泛接纳的Unicode字符编码方案,它采用可变长度的字节序列来表示字符,每个Unicode字符都对应一个独一无二的数字标识,即码点。UTF-8的一个显著特点是对ASCII字符(英文文本)保持不变,因此在网络传输和文件存储方面展现出优秀的兼容性。 GBK编码,正式名称为“汉字内码扩展规范”,是中国大陆的标准化编码,是对GB2312编码的延伸,总共涵盖了20902个汉字及其他符号,每个字符使用两个字节来表示。GBK在GB2312的基础上扩充了许多繁体字、少数民族文字以及特殊符号,目的是满足更广泛的语言需求。 将UTF-8转换为GBK的主要难点在于GBK是一种固定长度的双字节编码,而UTF-8则是可变长度的编码。转换过程中需要将UTF-8的多字节序列解析为相应的Unicode码点,然后依据GBK的编码规则查找匹配的编码。这一过程通常借助查表法完成,即建立一个从Unicode码点到GBK编码的映射库。 在Keil开发环境中,使用C语言实现UTF-8到GBK的转换可以遵循以下步骤: 1. **构建查表法所需的GBK编码库**:需要准备一个包含所有GBK字符二进制形式的GBK编码库。这个库通常是一个二进制文件,其大小大约为41KB。 2. **解析UTF-8编码**...
内容概要:本文提出一种基于CNN-BiGRU-Attention混合神经网络模型的风电功率预测方法,旨在提升风力发电功率预测的精度。该模型面向多变量输入的单步预测任务,首先利用卷积神经网络(CNN)提取风速、风向、温度等气象因素的局部时空特征,再通过双向门控循环单元(BiGRU)充分捕捉时间序列数据的前后向时序依赖关系,最终引入注意力(Attention)机制对关键历史时刻的特征进行自适应加权,强化对预测结果贡献更大的时间步信息,从而显著提高预测准确性。整个模型在Matlab平台上实现,特别适用于处理风电数据固有的强随机性与剧烈波动性,能够有效应对复杂多变气象条件下的功率预测挑战,为电网调度提供高精度的数据支撑。; 适合人群:具备一定机器学习和深度学习理论基础,熟悉Matlab编程语言,从事新能源发电预测、电力系统调度、智能算法开发与应用等相关领域的科研人员、工程技术人员及高校研究生。; 使用场景及目标:①应用于风电场实际运行中的短期功率预测,为电网的安全稳定调度与经济运行提供可靠依据;②作为深度学习在可再生能源预测领域应用的典型案例,帮助学习者深入理解CNN、RNN变体(BiGRU)及Attention机制的协同建模原理与实现方法;③为后续研究多步预测、模型轻量化或网络结构优化等方向提供坚实的技术参考和可复用的代码基础。; 阅读建议:学习者应重点关注模型各组件的设计思路与集成方式,结合提供的Matlab代码,系统掌握数据预处理、模型搭建、训练流程及性能验证的完整环节,建议通过调整输入变量组合、优化网络超参数或替换数据集等方式,观察模型性能变化,以深入理解该混合架构的核心优势与调优策略。
内容概要:本文系统阐述了基于多种改进型灰狼优化算法(包括GWO、MP-GWO、灰狼-布谷鸟混合优化算法及CS-GWO多种群算法)实现的无人机路径规划技术,并配套提供完整的Matlab代码实现方案。研究聚焦于在复杂地形与动态环境中,利用智能优化算法模拟灰狼群体的等级结构与协作捕食机制,以高效搜索全局最优飞行路径,提升无人机避障能力与路径规划精度。相较于传统方法,所采用的混合与多策略改进算法有效缓解了早熟收敛与陷入局部最优的问题,显著增强了算法的探索与开发平衡能力。此外,文档还展示了该技术在多学科交叉领域的广泛应用前景,涵盖路径规划、机器学习、信号处理、电力系统优化等科研方向,体现了较强的技术通用性与工程实用价值。; 适合人群:具备一定编程基础与Matlab使用经验,从事智能优化算法研究、无人机控制、自动导航、路径规划及相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于城市密集区、山区或存在动态障碍物的复杂场景下的无人机三维路径规划与实时避障;②为科研项目提供可复现的智能优化算法实现案例,支撑算法性能对比与创新改进;③服务于学术论文复现、毕业设计、课题开发等实际科研与教学需求,加速研究成果落地。; 阅读建议:建议结合Matlab代码与算法理论同步研习,重点分析各算法的参数设置、收敛特性及路径规划效果图,深入理解其优化机制差异,可进一步拓展至多无人机协同规划、动态环境适应等高级应用场景进行实践验证与创新研究。
已经博主授权,源码转载自 https://pan.quark.cn/s/7d6084144924 Linux系统管理员经常遭遇磁盘空间不足的挑战,这会导致磁盘读写操作受阻,同时使得应用程序无法正常运行。磁盘满载的原因多种多样,包括系统安装规划不当、日志文件急剧膨胀以及网络通信故障等。应对这一问题需要对磁盘空间进行清理和优化。本文将介绍十种磁盘清理策略,旨在帮助用户解决磁盘空间不足的困境。 1. 定期对关键文件系统进行扫描,并进行对比,以分析哪些文件频繁被访问 通过执行 `#IS-IR/home > files.txt` 和 `#diff filesold.txt files.txt` 命令,对重要文件系统实施扫描和对比,识别那些经常被读取和写入的文件,从而预判空间增长趋势,并考虑对不常访问的文件实施压缩,以减少其占用的存储空间。 2. 检查文件系统的 inodes 消耗情况 使用 `#df -i /home` 命令来检查空间文件系统的 inodes 消耗情况,如果仍有大量的 inodes 可用,表明是大文件占用了空间,否则可能是许多小文件占用了空间。 3. 识别占用空间较大的目录 使用 `#du -hs /home` 命令查看 `/home` 所占用的空间,并借助 `#du /awk $1 > 2000` 命令找出 `/home` 下占用空间超过 1000m 的目录。 4. 确定占用空间较大的文件 通过 `#find /home -size +2000K` 命令来找出占用空间较大的文件。 5. 查找最近修改或创建的文件 使用 `#TOUCH -t 08190800 test` 命令为某个文件设定一个特定的时间,然后运用 `#find /home -newer test -...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值