linux 自动定时清理缓存

简介: linux 自动定时清理缓存

在使用linux系统时,总会发现buff/cache过高,不清理的话一直挂在那,因此写了一个定时清理程序

1,查看内存占用情况:

free -h

6个字段列的意思分别是:

total:系统内存总大小

used:已使用内存

free:可用内存(剩余多少内存)

shared:多个进程共享的内存

buff/cache:系统缓存大小

available:还可以被使用的内存

左侧两个字段行的意思分别是:

  • Mem:物理内存空间使用情况,通常意义上的物理内存分区
  • Swap:交换空间使用情况(交换分区),物理内存不够用时,临时存放数据。

1.1、free和available的区别?

free 和 available 这两个字段都有“剩余内存”的意思,很多同学可能会对此产生疑惑,这里给大家简单解释一下这两个字段的区别:

free是未被使用的内存

available是程序“认为”还可以被使用的内存

Linux为了提高读写性能,会拿出一部分内存来临时存储数据(也就是系统缓存缓存),当剩余的内存(free)不够的时候,就会释放一部分缓存(buff/cache)来满足程序的使用需求。

即:available = free + buff/chche(部分可以被释放的缓存)

1.2、交换分区的作用?

free 命令有 Mem 和 Swap 两行查询结果,其中 Swap 就是交换分区的意思。

交换分区也叫交换空间(Swap space),本质上是磁盘上的一个区域,可以是一个分区,也可以是一个文件。

当系统的物理内存不够用时,就会把一部分不常用的数据临时放到交换分区(Swap),等到程序要使用这些数据时,再把它们从交换分区加载到物理内存中。

这就意味着,系统总是在内存不够用的情况下,才会使用交换分区。

如果交换分区没被使用或者使用的很少,内存够用(使用情况良好);反之,就说明内存不够用了,可能会影响到系统的使用。

交换分区可以在一定程度上解决内存不足的问题,但它会读取磁盘的数据,所以读写速度不快,因此,只有在内存不够用时,才会选择把数据放到交换分区。

那么,系统什么时候才会把物理内存的数据放到交换分区呢?

/etc/sysctl.conf 文件中有一个 swappiness 参数,用来控制交换数据的优先级,它的取值范围是0~100,0表示尽可能不把数据放到交换分区;100表示尽可能多的把数据放到交换分区。我们可以通过修改 swappiness 参数的值,来改变系统把内存的数据放到交换分区的迫切程度。

2,手动清理命令

sudo sync; sudo echo 3 | sudo tee /proc/sys/vm/drop_caches

3,定时自动清理

3.1,创建文件夹

mkdir -p /home/bin/sh/
cd /home/bin/sh

3.2,新建文件cleanBuffer.sh

vim cleanBuffer.sh

3.3,添加内容

#!/bin/bash
#每两小时清除一次内存buff/cache缓存
echo "开始清除缓存"
sync;sync;sync #写入硬盘,防止数据丢失
sleep 10 #延迟10秒
echo 3 > /proc/sys/vm/drop_caches

3.4,脚本文件授权

chmod +x cleanBuffer.sh

3.5,添加定时任务

crontab -e

3.6,插入内容

0 2 * * * /home/bin/sh/cleanBuffer.sh > /dev/null 2>&1 &
##每天凌晨2点清理一次

这里配置的是每天凌晨2点清理一次

注意:这里 /home/bin/sh/cleanBuffer.sh 文件是我们刚刚建立的清理文件

另外,这里的表达式长度是5位,不是6位,注意了,不然会报错的

3.7,查看定时任务

crontab -l

3.8,设置启动以及开机自启

systemctl start crond.service   # 开启
 
systemctl restart crond.service # 重启
 
systemctl enable crond.service  # 设置开机启动
 
systemctl status crond.service  # 查看运行状态


努力的时间还不够 哪有时间去绝望啊


目录
相关文章
|
20天前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
45 15
Android 系统缓存扫描与清理方法分析
|
3月前
|
安全 Linux 调度
在Linux中,如何实现,每星期天早8点服务器定时重启?
在Linux中,如何实现,每星期天早8点服务器定时重启?
|
7天前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
22 3
|
7天前
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
20 3
|
16天前
|
存储 缓存 监控
|
1月前
|
存储 缓存 固态存储
|
2月前
|
Unix Linux Python
Cron定时设置在linux和mac中的使用
文章详细说明了如何在Linux和Mac操作系统中使用Cron进行定时任务的设置,并提供了多个Cron表达式的实例。
38 0
|
3月前
|
缓存 安全 Linux
|
3月前
|
SQL 缓存 监控
实时计算 Flink版产品使用问题之怎么手动清理缓存或废弃文件
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。