linux学习之缓存机制
2017-09-01 18:17
330 查看
linux中的缓存机制
在Linux系统中,为了提高文件系统性能,内核利用一部分物理内存分配出缓冲区,用于缓存系统操作和数据文件,当内核收到读写的请求时,内核先去缓存区找是否有请求的数据,有就直接返回,如果没有则通过驱动程序直接操作磁盘。
缓存机制优点:减少系统调用次数,降低CPU上下文切换和磁盘访问频率。
CPU上下文切换:CPU给每个进程一定的服务时间,当时间片用完后,内核从正在运行的进程中收回处理器,同时把进程当前运行状态保存下来,然后加载下一个任务,这个过程叫做上下文切换。实质上就是被终止运行进程与待运行进程的进程切换。
区分buffers和cache
buffers
用来缓存metadata及pages,可以理解为系统缓存,例如,vi打开一个文件。
cached
是用来给文件做缓存,可以理解为数据块缓存,例如,dd if=/dev/zero of=/tmp/test count=1 bs=1G 测试写入一个文件,就会被缓存到缓冲区中,当下一次再执行这个测试命令时,写入速度会明显很快。
释放缓存的方式
清理pagecache(页面缓存)
# echo 1 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=1
清理dentries(目录缓存)和inodes
# echo 2 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=2
清理pagecache、dentries和inodes
# echo 3 > /proc/sys/vm/drop_caches 或者 # sysctl -w vm.drop_caches=3
上面三种方式都是临时释放缓存的方法,要想永久释放缓存,需要在/etc/sysctl.conf文件中配置:vm.drop_caches=1/2/3,然后sysctl -p生效即可!
还可以使用sync命令来清理文件系统缓存,还会清理僵尸(zombie)对象和它们占用的内存
(最好在清理缓存前进行此操作)
# sync
相关文章推荐
- 【linux】Linux学习总结-信号机制
- linux下的缓存机制及清理buffer/cache/swap的方法梳理
- 【django 学习笔记】14-缓存机制
- linux 驱动学习之list链表机制
- Glide缓存机制之硬盘缓存学习笔记
- 分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装
- 【嵌入式Linux学习七步曲之第四篇 Linux内核移植】详解Linux2.6内核中基于platform机制的驱动模型
- 【嵌入式Linux学习七步曲之第七篇 Linux的高级应用编程】Linux下的线程实现机制分析
- 分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装
- linux下的缓存机制及清理buffer/cache/swap的方法梳理
- Linux网络编程(3):信号处理与定时机制简要学习
- 【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】Linux内核抢占实现机制分析
- Linux下驱动:分层、分离机制学习笔记
- Linux信号产生与处理机制学习笔记(二)
- Linux缓存机制之块缓存
- 分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装
- linux模块机制学习笔记
- Hibernate学习---缓存机制
- Glide缓存机制之内存缓存学习笔记
- (五)JS学习笔记 - JQuery缓存机制