博客
关于我
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/

你可能感兴趣的文章
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>