博客
关于我
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_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>