centos7定时任务清除buff/cache

本文介绍了一个自动化的缓存清理脚本及其配置方法。通过编写shell脚本并结合crontab实现定时清理Linux系统的缓存,有效避免了手动操作带来的不便。文中详细解释了如何设置crontab定时任务来定期执行清理操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近有部分项目运行很卡,之前都是手动清理缓存,容易忘记,现在写个自动清理的脚本并加入到定时任务中

1、新建运行脚本

touch cleanCache.sh
vim cleanCache.sh 
echo "开始清除缓存"
sync;sync;sync #写入硬盘,防止数据丢失
sleep 10 #延迟10秒
echo 1 > /proc/sys/vm/drop_caches
echo 2 > /proc/sys/vm/drop_caches
echo 3 > /proc/sys/vm/drop_caches
chmod +x cleanCache.sh  ## 添加可执行权限

 2、crontab -e

*/1 * * * *  ## 每分钟执行一次,测试用

crontab -e  ## 修改 crontab 文件. 如果文件不存在会自动创建。
0 2 * * * /lanren312/cleanCache.sh > /dev/null 2>&1 &  ## 每天凌晨2点执行(注意,这里是5位数,写6位保存时就会报错)


*    *    *    *    *
-    -    -    -    -
|    |    |    |    |
|    |    |    |    +----- 星期中星期几 (0 - 6) (星期天 为0)
|    |    |    +---------- 月份 (1 - 12) 
|    |    +--------------- 一个月中的第几天 (1 - 31)
|    +-------------------- 小时 (0 - 23)
+------------------------- 分钟 (0 - 59)
crontab -l ## 显示 croab 文件

 3、开机启动

# 保证crond启动以及开机自启
systemctl start crond.service
systemctl enable crond.service

## 重启
systemctl restart crond.service
## 查看状态
systemctl status crond.service
## 查看定时任务是否被执行
cat /var/log/cron | grep cleanCache
或
tail -f -n100 /var/log/cron | grep cleanCache
crontab -r   ##  删除 crontab 文件
crontab -ir  ##  删除 crontab 文件前提醒用户

4、ubuntu

sudo crontab -e
0 4 * * * /data/start.sh
保存并退出(nano 下 Ctrl+O → Enter → Ctrl+X)

<think>我们被要求查看Linux系统中哪些进程占用了buff/cache。根据引用[2]和引用[4],我们可以使用一个名为`hcache`的工具来查看哪些进程占用了buffer/cache。###步骤说明:1.**安装hcache工具**:首先需要下载并安装`hcache`工具。该工具是`pcstat`的一个增强版本,可以显示每个进程占用的缓存情况。2.**使用hcache查看占用缓存的进程**:安装后,我们可以通过运行`hcache`命令来查看缓存占用情况。###具体操作:####1.下载并安装hcache根据引用[2],我们可以使用以下命令下载并安装:```bashwgethttps://silenceshell-1255345740.cos.ap-shanghai.myqcloud.com/hcachechmod755hcache&&mvhcache/usr/local/bin/```####2.使用hcache查看占用buff/cache的进程安装完成后,可以使用以下命令查看缓存占用情况:```bashsudohcache--top10```这个命令会显示占用缓存最多的前10个进程(包括它们缓存的文件和大小)。**常用选项**:-`--sort-by`:按指定字段排序(如`size`、`pid`等)-`--topN`:显示前N个结果-`--bname`:只显示二进制文件的名字(而不显示完整路径)**示例命令**:```bash#按缓存大小降序排列,显示前20个进程sudohcache--sort-bysize--top20#查看指定进程(如nginx)的缓存占用sudohcache-p$(pgrepnginx)```###替代方案:使用`smem`工具如果没有`hcache`,也可以使用`smem`工具查看内存占用情况(包括USS/PSS/RSS):```bash#安装smemsudoaptinstallsmem#Debian/Ubuntusudoyuminstallsmem#CentOS/RHEL#按PSS排序显示进程内存smem-spss-r```###手动分析(不推荐)如果不想安装额外工具,可以通过以下步骤手动分析(但比较繁琐):1.使用`find`命令查找被缓存的文件:```bashsudofind/proc/*/fd-typel-lname'/*'-execls-l{}\;2>/dev/null```2.结合`lsof`命令查看哪些进程打开了这些文件:```bashlsof-p<pid>```>**注意**:手动分析过程复杂且不直观,强烈建议使用`hcache`工具[^2][^4]。---###缓存回收建议如果确定某些进程占用的缓存不再需要,可以尝试手动释放缓存(根据引用[1]和引用[3]):```bash#释放pagecacheecho1>/proc/sys/vm/drop_caches#释放slab分配器中的对象echo2>/proc/sys/vm/drop_caches#同时释放pagecache和slabecho3>/proc/sys/vm/drop_caches```**注意**:释放缓存是临时性的,新的文件操作会重新占用缓存。生产环境谨慎操作,可能影响性能[^1][^3]。§§相关问题§§1.如何防止Linux系统缓存(buff/cache)占用过高?2.除了`hcache`,还有哪些工具可以查看内存缓存占用?3.为什么Linux系统会使用buff/cache?它有什么作用?4.手动释放buff/cache对系统性能有什么影响?</think>### 查看Linux中占用buff/cache的进程 在Linux系统中,buff/cache主要用于磁盘读写缓存和内存管理。要查看具体哪些进程占用了buff/cache,推荐以下方法: #### 1. 使用`hcache`工具(最推荐) ```bash # 安装hcache wget https://silenceshell-1255345740.cos.ap-shanghai.myqcloud.com/hcache chmod 755 hcache && sudo mv hcache /usr/local/bin/ # 查看占用buff/cache最多的前10个进程 sudo hcache --sort-by cache -t 10 ``` **输出示例**: ``` PID NAME SIZE CACHE 1234 java 1.2GB 850MB 5678 nginx 320MB 210MB 9012 mysql 500MB 180MB ... ``` **参数说明**: - `--sort-by cache`:按缓存占用排序 - `-t N`:显示前N个进程[^2] #### 2. 使用`smem`工具(无需安装) ```bash # 安装smem(Debian/Ubuntu) sudo apt install smem # 查看缓存占用 smem -s swap -r -k -c "pid user command swap uss pss rss cache" ``` **关键列**: - `cache`:进程占用的缓存大小 - `rss`:常驻内存集大小 - `pss`:按比例分配的内存大小[^4] #### 3. 使用`pcstat`工具(文件级分析) ```bash # 安装pcstat go get github.com/tobert/pcstat # 查看特定进程的缓存文件 pcstat -pid $(pgrep nginx) ``` #### 4. 手动分析(基础方法) ```bash # 1. 找到缓存占用大的内存页 grep -r ^ /proc/*/smaps 2>/dev/null | awk '/^\/proc/{match($0,"[0-9]+",a);pid=a[0]}/Size:/{size+=$2}/Shared_Clean:/{clean+=$2}END{print pid,size" kB",clean" kB"}' | sort -k3 -nr # 2. 根据PID查进程名 ps -p <PID> -o comm= ``` ### 缓存管理建议 如果发现特定进程占用过多缓存: ```bash # 释放缓存(生产环境慎用) echo 3 | sudo tee /proc/sys/vm/drop_caches ``` **注意**: 1. 缓存Linux性能优化机制,无需频繁清理 2. 优先分析异常进程而非直接清缓存 3. 数据库服务(如MySQL)会主动使用缓存提升性能[^3][^4] --- ### 关键原理说明 - **buff**:块设备缓冲,用于磁盘读写加速 - **cache**:文件系统缓存,存储频繁访问的文件 - 两者都可通过`drop_caches`释放: ```bash echo 1 > /proc/sys/vm/drop_caches # 释放pagecache echo 2 > /proc/sys/vm/drop_caches # 释放slab缓存 echo 3 > /proc/sys/vm/drop_caches # 同时释放两者[^1][^3] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值