Linux-Memory小记

Linux-Memory小记

大家好,又见面了,我是全栈君。

以前我对这块认识很模糊,而且还有错误的认识;今天由我同事提醒,所以我决定来好好的缕缕这块的关系。

图:
Linux-Memory小记

Linux-Memory小记
  

——————————————-1.参数含义———————————————————————–
Mem:表示物理内存统计
   total: 表示系统总物理内存5993156kb(约5852M)
   used: 表示总计分配给缓存(包含buffers 与cached),但其中可能部分缓存未实际使用
   free:表示未分配的内存
   shared: 表示共享内存
   buffers:表示系统分配但未被使用的buffers数量
   cached:表示系统分配但未被使用的cache的数量

在Free命令中显示的buffer和cache,它们都是占用内存:
buffer :   作为buffer cache的内存,是块设备的读写缓冲区,更靠近存储设备,或者直接就是disk的缓冲区。
cached:  作为page cache的内存, 文件系统的cache,是memory的缓冲区 。
如果cached 的值很大,说明cache住的文件数很多。如果频繁访问到的文件都能被cache住,那么磁盘的读IO 必会非常小 。

-/+ buffers/cached:   表示物理内存的缓存统计
   used: 表示实际使用的buffers与cache的总量,这就是实际使用的内存总量
   free:  表示未被使用的buffers与cache和未被分配的内存之和,这就是系统当前实际可能内存(所以一般linux机器看可用内存就看此值)

Swap:   表示硬盘上交换分区的使用情况。只有mem被当前进程实际占用完,即没有了buffers和cache时,才会使用到swap。

——————————————-2.常用概念———————————————————————–
物理内存总大小 :
mem.total=mem.used+mem.free
mem.total=(-/+ buffers/cached).used+(-/+ buffers/cached).free

已经分配的内存大小:
mem.used=mem.buffers+mem.cached+(-/+ buffers/cached).used

实际可用内存大小:
(-/+ buffers/cached).free=mem.free+mem.buffers+mem.cached

——————————————-3.手工清除缓存——————————————————————
# sync
# echo 1 > /proc/sys/vm/drop_caches
  echo 2 > /proc/sys/vm/drop_caches
  echo 3 > /proc/sys/vm/drop_caches

cache释放:
a.To free pagecache:
echo 1 > /proc/sys/vm/drop_caches

b.To free dentries and inodes:
echo 2 > /proc/sys/vm/drop_caches

c.To free pagecache, dentries and inodes:
echo 3 > /proc/sys/vm/drop_caches

说明,释放前最好sync一下,防止丢数据。

——————————————-4.常见疑惑———————————————————————–
1.用户常见的疑问是,为什么free这么小,是否关闭应用后内存没有释放?
   但实际上,我们都知道这是因为Linux对内存的管理与Windows不同,free小并不是说内存不够用了,应该看的是free的第二行最后一个值:-/+ buffers/cache: 2592892Kb,这才是系统可用的内存大小。

2.free内存还有200M,cache里有58G,然后程序就跪了,抛了个tcmalloc allocation failed 65536, out of memory(needed 65312 bytes). 需要内存时为什么cache里面的没能释放?
   cache 中有程序在占用就无法释放了。

3.有时候free太小,cached特别大时启动mysql会报错,这个是什么原因?
    这说明内存确实不够,cached并不是全部可以释放的,有程序占用就不能释放了

4.我的Linux上cache占满RAM时系统非常慢,系统也不自动释放cache。所以号称“cache对性能只有好处而没坏处”是假的!
   这个要看你实际是使用的应用是什么。cache能带来的好处是,减轻频繁读写硬盘的需要,也就是降低IO,这特别是对于服务器上的应用来说是很常见的。相反,如果cache需要频繁更新,那会出现您提到的问题了

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108707.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 比SQL还好用,又一门国产数据库语言诞生了「建议收藏」

    比SQL还好用,又一门国产数据库语言诞生了「建议收藏」数据库语言,你会哪几种?写得简单又跑的快,它来了……

    2022年10月6日
    3
  • 简单利用conda安装tensorflow-gpu=2.2.0

    简单利用conda安装tensorflow-gpu=2.2.0网上安装tensorflow-gpu=2.2.0什么的一大推,而且最后还报错,一般问题出现在:一、安装下载慢二、cuda和cudnn版本不对我最后实验了,很好解决上面的问题。一、安装tensorflow-gpu=2.2.0使用清华源安装,代码如下:pipinstalltensorflow-gpu==2.2.0-ihttps://pypi.tuna.tsinghua.edu.cn/simple这样下载速度飞起!二、什么去官网下载cuda版本配置路径,感觉都不靠谱,我实验了,一个命令搞定

    2022年6月15日
    37
  • 微服务分布式事务解决方案Seata

    微服务分布式事务解决方案Seata文章目录一 pandas 是什么 二 使用步骤 1 引入库 2 读入数据 总结一 什么是 Seata Seata 是一款开源的分布式事务解决方案 致力于提供高性能和简单易用的分布式事务服务 Seata 将为用户提供了 AT TCC SAGA 和 XA 事务模式 为用户打造一站式的分布式解决方案 AT 模式是阿里首推的模式 阿里云上有商用版本的 GTS GlobalTransa 全局事务服务 提示 业务场景 角色划分

    2025年11月1日
    3
  • 免备案云服务器选香港好还是美国好

    免备案云服务器租用哪里的?免备案云服务器主要是指那些不受国内工信部约束管理的主机产品。也就是说,国内工信部管理的大陆地区云服务器产品需要备案,海外其他国家的主机是不用备案的,比较特殊的是中国香港主机、澳门和台湾空间产品,也是不用备案的。大家常用的免备案云服务器是香港和美国云服务器,这两地的技术发达,云服务器的性能完善,包含防攻击、数据备份、弹性伸缩、平台安全性保证,可支持软硬件在线升级等等。美国云服务器美国云服务中心拥有高级的安保措施,数据安全性和服务稳定性是世界一流标准。ip资源丰富,价格低廉,在

    2022年4月9日
    58
  • Modbus通讯协议详细解释

    Modbus通讯协议详细解释Modbus一个工业上常用的通讯协议、一种通讯约定。Modbus协议包括RTU、ASCII、TCP。其中MODBUS-RTU最常用,比较简单,在单片机上很容易实现。先来简单分析一条MODBUS-RTU报文,例如:0106000100179804010600010017

    2022年7月12日
    16
  • java 错误: 找不到符号遇到的几种情况

    java 错误: 找不到符号遇到的几种情况今天在学习java面向对象的时候写了两个类,在运行时出现了以下错误:然后下面是我的两个java类publicclassArrayTool{ ArrayTool(){ } publicintgetMax(int[]arr){ intmax=0; for(inti=0;i

    2022年7月8日
    22

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号