博客
关于我
linux下的小知识
阅读量:301 次
发布时间:2019-03-01

本文共 1285 字,大约阅读时间需要 4 分钟。

目录

操作系统

free下的buff/cache

buff: 即写入磁盘时,先保存到磁盘缓冲区(buffer),然后再写入到磁盘。

cache: 即读磁盘时,数据从磁盘读出后,暂留在缓冲区(cache),为后续程序的使用做准备。

操作系统的角度: 这块内存确实被操作系统使用了。

用户角度: 如果用户要使用,这块内存是可以很快被回收而被用户空间程序使用,因此从用户角度而言这块内存应被划为空闲状态。
在这里插入图片描述
Linux内核会在内存将要耗尽的时候,触发内存回收的工作,以便释放出内存给急需内存的进程使用。一般情况下,这个操作中主要的内存释放都来自于对buffer/cache的释放。尤其是被使用更多的cache空间。既然它主要用来做缓存,只是在内存够用的时候加快进程对文件的读写速度,那么在内存压力较大的情况下,当然有必要清空释放cache,作为free空间分给相关进程使用。

这是Linux一种非常优秀的设计,目的就是为了提升磁盘IO的性能,从低速的块设备上读取的数据会暂时保存在内存中,即使数据在当时已经不再需要了,但在应用程序下一次访问该数据时,它可以从内存中直接读取,绕开了低速的块设备,从而提高系统的整体性能。

清除cache中的缓存

$echo 0 > /proc/sys/vm/drop_caches		#不释放缓存$echo 1 > /proc/sys/vm/drop_caches 		#表示清除pagecache。$echo 2 > /proc/sys/vm/drop_caches		#表示清除回收slab分配器中的对象(包括目录项缓存和inode缓存)。slab分配器是内核中管理内存的一种机制,其中很多缓存数据实现都是用的pagecache。$echo 3 > /proc/sys/vm/drop_caches		#表示清除pagecache和slab分配器中的缓存对象。

将buff中的数据刷到磁盘上

sync

测试

使用find查找文件:keystone-error.log

#首次查询$ time find / -name keystone-error.log/var/log/httpd/keystone-error.logreal	0m1.940suser	0m0.162ssys	0m0.875s#二次查询(此时数据以及被缓存了)$ time find / -name keystone-error.log/var/log/httpd/keystone-error.logreal	0m0.598suser	0m0.233ssys	0m0.362s#清除缓存$ echo 3 > /proc/sys/vm/drop_caches $ time find / -name keystone-error.log/var/log/httpd/keystone-error.logreal	0m1.160suser	0m0.205ssys	0m0.795s

在这里插入图片描述

由上面的小测试可以看出,在做重复的操作,或者打开重复的文件时,cache是对性能有很大的提升

转载地址:http://lcwl.baihongyu.com/

你可能感兴趣的文章
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
mysql problems
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>