加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

Linux内存、Swap、Cache、Buffer详细解析

发布时间:2022-07-14 16:10:45 所属栏目:Linux 来源:互联网
导读:1. 通过free命令看Linux内存 total:总内存大
   1. 通过free命令看Linux内存
  
 
  total:总内存大小。
  used:已经使用的内存大小(这里面包含cached和buffers和shared部分)。
  free:空闲的内存大小。
  shared:进程间共享内存(一般不会用,可以忽略)。
  buffers:内存中写完的东西缓存起来,这样快速响应请求,后面数据再定期刷到磁盘上。
  cached:内存中读完缓存起来内容占的大小(这部分是为了下次查询时快速返回)。
  -/+ buffers/cache看做两部分:
 
 
  2. Buffer和Cache介绍
  
 
  Cache(缓存),为了调高CPU和内存之间数据交换而设计,Buffer(缓冲)为了提高内存和硬盘(或其他I/O设备的数据交换而设计)。
 
  Cache主要是针对读操作设计的,不过Cache概念可能容易混淆,我理解为CPU本身就有Cache,包括一级缓存、二级缓存、三级缓存,我们知道CPU所有的指令操作对接的都是内存,而CPU的处理能力远高于内存速度,所以为了不让CPU资源闲置,Intel等公司在CPU内部集成了一些Cache,但毕竟不能放太多电路在里面,所以这部分Cache并不是很大,主要是用来存放一些常用的指令和常用数据,真正大部分Cache的数据应该是占用内存的空间来缓存请求过的数据,即上面的Cached部分(这部分纯属个人理解,正确与否有待考证)。
 
 
  3. 常见症状
  症状一:在Linux中频繁存取文件,物理内存很快用光,而cached一直在增长。
 
  解释:Linux会对每次请求过的数据缓存在cache里,好处就是CPU的处理速度远远高于内存,所以在CPU和内存通讯的时候可以快速从cache中命中结果返回。
 
  症状二:Swap被占用。
 
  解释:内存可能不够了,才会占Swap,所以Swap可以作为服务器监控的一项指标,引起注意。
 
  4. 手动清理Swap和buffers/cache
  (1) 清理Swap
 
  
 
  操作说明:如果已经使用了Swap,且当前清空下+buffers/cache还有空间,在执行  swapoff -a操作时,会触发把Swap中的内容交换到内存中,数据不会丢失。
 
  (2) 清理buffers/cache:
 
  
 
  操作说明:
 
  
 
  5. 总结
  通过上面的分析可以知道,当空闲物理内存不多时,不一定表示系统运行状态很差,因为内存的cache及buffer部分可以随时被重用,在某种意义上,这两部分内存也可以看作是额外的空闲内存。
 
  swap如果被频繁调用,bi,bo长时间不为0,则才是内存资源是否紧张的依据。通过free看资源时,实际主要关注-/+ buffers/cache的值就可以知道内存到底够不够了。

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读