linux 内存学习

free -m

total 是总内存大小
used 已经使用的,包含共享内存
free 未使用的内存
shared 共享内存大小
buff/cache 缓存 、缓冲大小
available 新进程可使用的大小内存 available 不仅包含 free内存 还包含可以回收的内存,所以一般会比 free大。

buffer 缓冲区,用于存储速度不同或者优先级不同 速度慢的设备和速度快的设备进行通信时, 速度慢的设备会先把数据存进buffer中
等到一定成都,存储快的设备 会一次性读取。在此期间,速度快的cpu 可以搜索干其他事儿

例如: 一般写入磁盘, 进程在要求读入某些数据的时候,当所有读取的数据被读取的时候,已经读取的数据首先放进buffer里面

cache 高速
缓存区, cpu的速度远远高于内存的速度。从内存中读取数据等待时间比较长。而 cache 保存这cpu刚用过的数据或循环使用的数据,这时cpu从 cache中读取比较快。减少了 cpu的处理时间,提供系统性能

cache 并不缓存文件,缓存块 块是 I/O的最小单元。cache 一般会用着I/O请求上, 如 多个进程要访问某个文件,可以把此文件认为成cpu 循环使用的数据, 读入到 cache中。这样下一个进程cpu 直接读取cache 提高系统能力

系统内存被耗尽的时候,会回收 caches。 数据落地进行回收,所以一般伴着 内存会后,I/O会飙升。
手动清理 echo 1 > /proc/sys/vm/drop_caches
2
3
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分配器中的缓存对象。

top

VIRT 是 进程使用的虚拟内存,res 是使用的真实内存,SHR 是共享内存。
res 不包含 SHR, SHR 保函 代码,动态链接库,共享内存
MEM 是占用的总内存的百分比

进程查看的方式

free top htop vmstat cat /proc/meminfo

vmstat

r 代表表示运行队列(就是说多少个进程真的分配到CPU) 如果超过cpu个数 就代表出现cpu瓶颈了。
b 代表内存阻塞
swpd 代表虚拟内存使用, 大于0 代表物理内存不够。
free 代表空闲内存
buff 代表缓冲内存
cache 代表缓存内存
si 虚拟内存读取磁盘,大于0 代表物理内存不够。
so 虚拟内存 写入磁盘大小 同上不能大于0
bi 块设备,磁盘每秒接收的块数 默认 块 1024byte
bo 每秒发送的块数
in cpu 中断
cs 内存每秒上下文切换,数量大的话,代表 cpu大部分都浪费到 上下文切换
us 用户cpu使用时间
sy 系统cpu 使用
id 空闲cpu
wa 等待io的cpu时间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值