CentOS 6.x系统中的free
free [-b|-k|-m|-g|-h] [-l] [-o] [-t] [-s delay] [-c count] [-V]

-b        #-k,-m,-g 以单位bytes, KB, MB, 或 GB输出
-h        #以人类易读的方式输出(根据数值大小自动决定使用的单位)

-l        #显示高低内存详细统计信息

-o       #使用老的格式输出(没有-/+buffers/cache行)

-s delay     #每个多少秒,动态输出
-c count     #配合-s选项使用,总共输出多少次

-V       #显示该软件的版本信息

[root@python ~]# free  -th

  total       used       free     shared    buffers     cached

Mem:          980M       327M       652M       224K        36M       189M

-/+ buffers/cache:       101M       879M

Swap:         999M         0B       999M

Total:        1.9G       327M       1.6G

total = used + free
101 = 327 - 224k - 36 - 189
879 = 652 + 36 + 189 (这里少1M是由于单位转换导致)

第一部分Mem行:

total内存总数: 980M
used已经使用的内存数: 327M
free空闲的内存数: 652M
shared当前已经废弃不用,总是0(CentOS 6.x中貌似仍然可使用)
buffers Buffer缓存内存数: 36 M
cached Page缓存内存数: 189M

关系:total = used + free + shared (used = shared+buffers+cached+应用程序使用 327M = 224K + 36M + 189M + 应用程序使用)

第二部分(-/+ buffers/cache):
(-buffers/cache) used内存数,表示实际被程序占用的内存数:101M (指的第一部分Mem行中的used - buffers - cached - shared)
(+buffers/cache) free内存数,程序仍然可以挪用的内存数: 879M (指的第一部分Mem行中的free + buffers + cached)

第二行(mem)的used/free与第三行(-/+ buffers/cache) used/free的区别:

这两个的区别在于使用的角度来看:
第二行是从OS的角度来看,因为对于OS,buffers/cached 都是属于被使用
总的包括:内核(OS)使用 + Application(X,oracle,etc)使用 + buffers + cached.

第三行所指的是从应用程序角度来看,对于应用程序来说,buffers/cached 是等于可用的,
因为buffer/cached是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收。
所以从应用程序的角度来说,可用内存=系统free memory + buffers + cached.

第三部分是指交换分区

buffers与cached的区别。
buffers是指用来给块设备做的缓冲大小,他只记录文件系统的metadata以及 tracking in-flight pages.cached是用来给文件做缓冲。
就是说:buffers是用来存储,目录里面有什么内容,权限等等。
形象比喻:看在线视频网速慢时,视频中央一直在转圈,此时就是buffer,写数据

cached直接用来记忆我们打开的文件,如果你想知道他是不是真的生效,可以试一下,
先后执行两次命令#man X ,你就可以明显的感觉到第二次的开打的速度快很多。
形象比喻:在线视频下载完成后,再次去看,速度很快,此时是cache,读数据

为了清除缓存的cache,可以采用以下命令:
To free pagecache:
echo 1 > /proc/sys/vm/drop_caches

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

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

CentOS 6.x系统中的freefree  [-b|-k|-m|-g|-h]     [-l]    [-o]     [-t]   [-s delay]   [-c count]   [-V]
-b#-k,-m,-g 以单位bytes, KB, MB, 或 GB输出-h #以人类易读的方式输出(根据数值大小自动决定使用的单位)
-l#显示高低内存详细统计信息
-o#使用老的格式输出(没有-/+buffers/cache行)
-s  delay   #每个多少秒,动态输出-c  count   #配合-s选项使用,总共输出多少次
-V  #显示该软件的版本信息

[root@python ~]# free  -th             total       used       free     shared    buffers     cachedMem:          980M       327M       652M       224K        36M       189M-/+ buffers/cache:       101M       879MSwap:         999M         0B       999MTotal:        1.9G       327M       1.6G
              total =    used   +   free  101 = 327 - 224k - 36 - 189  879 = 652 + 36 + 189  (这里少1M是由于单位转换导致)
第一部分Mem行:
total内存总数: 980Mused已经使用的内存数: 327Mfree空闲的内存数: 652Mshared当前已经废弃不用,总是0(CentOS 6.x中貌似仍然可使用)buffers Buffer缓存内存数: 36 Mcached Page缓存内存数:189M
关系:total = used + free + shared (used = shared+buffers+cached+应用程序使用  327M = 224K + 36M + 189M + 应用程序使用)
第二部分(-/+ buffers/cache):(-buffers/cache) used内存数,表示实际被程序占用的内存数:101M (指的第一部分Mem行中的used - buffers - cached - shared)(+buffers/cache) free内存数,程序仍然可以挪用的内存数: 879M   (指的第一部分Mem行中的free + buffers + cached)
第二行(mem)的used/free与第三行(-/+ buffers/cache) used/free的区别: 
这两个的区别在于使用的角度来看: 第二行是从OS的角度来看,因为对于OS,buffers/cached 都是属于被使用总的包括:内核(OS)使用 + Application(X,oracle,etc)使用 + buffers + cached.

第三行所指的是从应用程序角度来看,对于应用程序来说,buffers/cached 是等于可用的,因为buffer/cached是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收。 所以从应用程序的角度来说,可用内存=系统free memory + buffers + cached.

第三部分是指交换分区

buffers与cached的区别。 buffers是指用来给块设备做的缓冲大小,他只记录文件系统的metadata以及 tracking in-flight pages.cached是用来给文件做缓冲。就是说:buffers是用来存储,目录里面有什么内容,权限等等。形象比喻:看在线视频网速慢时,视频中央一直在转圈,此时就是buffer,写数据 
cached直接用来记忆我们打开的文件,如果你想知道他是不是真的生效,可以试一下,先后执行两次命令#man X ,你就可以明显的感觉到第二次的开打的速度快很多。 形象比喻:在线视频下载完成后,再次去看,速度很快,此时是cache,读数据

为了清除缓存的cache,可以采用以下命令:To free pagecache:   echo 1 > /proc/sys/vm/drop_caches    To free dentries and inodes:   echo 2 > /proc/sys/vm/drop_caches  
To free pagecache, dentries and inodes:   echo 3 > /proc/sys/vm/drop_caches

free指令的说明的更多相关文章

  1. iOS逆向工程之Hopper中的ARM指令

    虽然前段时间ARM被日本软银收购了,但是科技是无国界的,所以呢ARM相关知识该学的学.现在看ARM指令集还是倍感亲切的,毕竟大学里开了ARM这门课,并且做了不少的实验,当时自我感觉ARM这门课学的还是 ...

  2. 步入angularjs directive(指令)--点击按钮加入loading状态

    今天我终于鼓起勇气写自己的博客了,激动与害怕并存,希望大家能多多批评指导,如果能够帮助大家,也希望大家点个赞!! 用angularjs 工作也有段时间了,总体感觉最有挑战性的还是指令,因为没有指令的a ...

  3. Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具

    前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较 ...

  4. 浅谈JSP中include指令与include动作标识的区别

    JSP中主要包含三大指令,分别是page,include,taglib.本篇主要提及include指令. include指令使用格式:<%@ include file="文件的绝对路径 ...

  5. [Django]用户权限学习系列之User权限基本操作指令

    针对Django 后台自带的用户管理系统,虽说感觉还可以,但是为了方便用户一些操作,特别设计自定义的用户权限管理系统. 在制作权限页面前,首先需要了解权限和用户配置权限的指令,上章讲到权限的添加,删除 ...

  6. 机器指令翻译成 JavaScript —— No.5 指令变化

    上一篇,我们通过内置解释器的方案,解决任意跳转的问题.同时,也提到另一个问题:如果指令发生变化,又该如何应对. 指令自改 如果指令加载到 RAM 中,那就和普通数据一样,也是可以随意修改的.然而,对应 ...

  7. ARM的栈指令

    ARM的指令系统中关于栈指令的内容比较容易引起迷惑,这是因为准确描述一个栈的特点需要两个参数: 栈地址的增长方向:ARM将向高地址增长的栈称为递增栈(Descendent Stack),将向低地址增长 ...

  8. IL指令详细表

    名称 说明 Add 将两个值相加并将结果推送到计算堆栈上. Add.Ovf 将两个整数相加,执行溢出检查,并且将结果推送到计算堆栈上. Add.Ovf.Un 将两个无符号整数值相加,执行溢出检查,并且 ...

  9. Angular学习-指令入门

    1.指令的定义 从用户的角度来看,指令就是在应用的模板中使用的自定义HTML标签.指令可以很简单,也可以很复杂.AngularJS的HTML编译器会解析指令,增强模板的功能.也是组件化未来的发展趋势, ...

  10. AngularJS之一个元素上绑定多个指令作用域

    前言 众所周知,我们在自定义指令时,会指定它的作用域,即scope设置项(默认值为false). 且,scope设置项,可以有三种值,从而也就代表三种不同的作用域,下面我们再来一起回顾下: 指令之sc ...

随机推荐

  1. Maven - settings.xml简易配置Demo

    前言 这里贴一下settings.xml的一个简易配置demo,就是简单配置了:本地的仓库地址.阿里云镜像.指定使用jdk1.8进行编译. 这里使用的Maven是3.5.0版本的. 配置文件demo ...

  2. [題解/狀壓dp]POJ_2411_Mondriaan's dream

    关于“我读过很多书,到后来大部分都被我忘记了,那阅读的意义是什么?”的疑问,我看过最巧妙的一个回答:当我还是个孩子的时候,我吃过很多的食物,大部分已经一去不复返而且被我忘记了,但可以肯定的是,它们中的 ...

  3. Points on Plane Codeforces - 576C

    https://www.luogu.org/problemnew/show/CF576C 看题面,一眼按莫队的方法排一下 直接交就会和我一样发现WA掉了... 算一下会发现,上限是3e9(块内左端点1 ...

  4. Oracle 云计算

    OCM(oracle 应用整合服务器,人工智能) XCM(exdata) BCM (大数据机器) 云运维人员 ,不需要本地人员

  5. Java的Cloneable接口还有深浅复制

    我的小记录 首先语法上,搞清除,Java有个Cloneable接口,但这个接口是没有定义方法的. 那实现了这个接口有什么用呢? 再看Object类中,有个clone()方法,这个方法提供一个浅复制的功 ...

  6. WPF中获取指定坐标依赖对象数据项

    上图中红色框区域是一个自定义的ListBox控件,需要实现的功能是,点击红框区域中某项时,获取当前选中项的数据项 控件的MouseDown事件部分代码为: var x = TreeHelper.Fin ...

  7. Java设计模式之单例模式 - Singleton

    用来创建独一无二的,是能有一个实例的对象的入场券.告诉你一个好消息,单例模式的类图可以说是所有模式的类图中最简单的,事实上,它的类图上只有一个类!但是,可不要兴奋过头,尽管从类设计的视角来说很简单,但 ...

  8. 【转】onAttachedToWindow()在整个Activity生命周期的位置及使用

    上篇博客实现圆角对话框样式的Activity中提到,若需实现圆角对话框Activity,需要在Activity的onAttachedToWindow()函数中做文章,那么就想问: onAttached ...

  9. kafka-->storm-->mongodb

    目的: 通过Spout发射kafka的数据,到bolt统计每一个单词的个数,将这些记录更新到mongodb中. Spout的nextTuple方法会一直处于一个while循环这中,每一条数据发送给bo ...

  10. CF1043D Mysterious Crime

    思路: 参考了http://codeforces.com/blog/entry/62797,把第一个序列重标号成1,2,3,...,n,在剩下的序列中寻找形如x, x + 1, x + 2, ...的 ...