皮皮网
皮皮网

【小米手机源码输出】【webdkp源码】【blockedqueue源码】linuxfree命令源码_linux命令 free

时间:2025-01-07 21:24:40 来源:潜伏主图 源码

1.linux下free命令如何使用
2.linux free命令
3.linux free命令详解
4.Linux之free命令
5.Linux系统中的命码l命令内存清理和释放命令归纳
6.linux free命令

linuxfree命令源码_linux命令 free

linux下free命令如何使用

       首先我们介绍命令的格式为 free [参数]。

       介绍第一条命令"free"显示内存的令源使用信息。默认按照M的命码l命令计数单位统计。

       显示各个参数说明:

       total表示 总计物理内存的令源大小。

       used表示 已使用多少。命码l命令

       free表示 可用内存多少。令源小米手机源码输出

       Shared表示 多个进程共享的命码l命令内存总额。

       Buffers/cached表示 磁盘缓存的令源大小。

       第三行(-/+ buffers/cached)解释

       used:已使用多大。命码l命令

       free:可用有多少。令源

       第四行是命码l命令交换分区SWAP的,也就是令源我们通常所说的虚拟内存。

       我们按照系统应用程序来说:系统可用内存= 系统free+buffers+cached。命码l命令

       下一条命令"free -g",令源按照g的计数方式来显示内存信息。

       下一条命令"free -m",命码l命令按照M的计数方式来显示内存信息。

       下一条命令"free -k",按照K的计数方式来显示内存信息。

       下一条命令"free -t",按照总和的形式显示内存的使用信息。

       下一条命令"free -s 2 -c 4"。表示为周期性展示统计内存信息。本篇实例为每隔2秒统计一次,统计4次。

       下一条命令"free -s 5",表示周期性展示内存使用情况,意思为每隔5秒统计展示,直到我们按下ctrl +c 键取消统计为止。

       如果需要查看版本信息,我们执行命令"free -V",进行查看。

linux free命令

       Mem:表示物理内存统计

       -/+ buffers/cached:表示物理内存的缓存统计

       Swap:表示硬盘上交换分区的使用情况,

       第1行 Mem:

       total:表示物理内存总量。webdkp源码

       used:表示总计分配给缓存(包含buffers 与cache )使用的数量,但其中可能部分缓存并未实际使用。

       free:未被分配的内存。

       shared:共享内存,一般系统不会用到,这里也不讨论。

       buffers:系统分配但未被使用的buffers 数量。

       cached:系统分配但未被使用的cache 数量。buffer 与cache 的区别见后面。

       total = used + free

       第2行 -/+ buffers/cached:

       used:也就是第一行中的used - buffers-cached 也是实际使用的内存总量。

       free:未被使用的buffers 与cache 和未被分配的内存之和,这就是系统当前实际可用内存。

linux free命令详解

       free命令用于显示内存状态。free 命令能够显示系统上的空闲和已用内存,还有交换内存,同时,也能显示被内核使用的缓冲和缓存。

       语法:free [-bkmotV][-s <间隔秒数>]

       参考例子:

       显示内存使用情况:

       [root@linux ~]# free

       参数:

       -b 以Byte显示内存使用情况

       -k 以kb为单位显示内存使用情况

       -m 以mb为单位显示内存使用情况

       -g 以gb为单位显示内存使用情况

       -s 持续显示内存

       -t 显示内存使用总合

Linux之free命令

       free命令在Linux系统中扮演着显示内存使用情况的关键角色,它能显示出物理内存、swap内存以及内核使用的buffer。此命令是系统监控工具中频繁使用的。

       free命令的格式是free[参数]。

       其主要功能是展示系统内存的使用与空闲状态,包括物理内存、swap内存和内核缓冲区内存,而共享内存则被忽略。

       关于buffers和cached的区别,我们需要了解buffer和cache的blockedqueue源码定义。buffer指的是buffer cache,通常翻译为“缓冲区”,它是针对磁盘块的读写操作。而cache指的是page cache,翻译为“页高速缓存”,它主要是内核实现的磁盘缓存,用来减少对磁盘的I/O操作。buffer cache没有文件概念,只是将磁盘上的块直接搬到内存中。而page cache缓存的是内存页面,它可以缓存普通文件、块设备文件和内存映射文件的读写操作。

       在free命令的输出中,free列代表真正未被使用的物理内存数量,而available列则是从应用程序的角度看的可用内存数量。Linux内核会将一部分内存用于缓存磁盘数据,当应用程序需要内存时,内核会从buffer和cache中回收内存来满足需求。所以,从应用程序的角度来看,available等于free加上buffer和cache。

       swap space是磁盘上的一块区域,可以是分区也可以是文件。当系统物理内存不足时,Linux会将其中的不常用数据保存到swap空间上,这样可以释放更多的物理内存为进程服务。交换空间可以在一定程度上缓解内存不足的情况,但其读写磁盘数据的Layres源码性能并不高。内核提供了swappiness参数来配置内存数据移到swap的紧迫程度,其取值范围是0到。

Linux系统中的内存清理和释放命令归纳

       # 清理步骤

       # 清理前内存使用情况

       代码如下:

       free -m

       # 开始清理

       代码如下:

       echo 1 /proc/sys/vm/drop_caches

       # 清理后内存使用情况

       代码如下:

       free -m

       完成!

       # 查看内存条数命令:

       复制代码

       代码如下:

       dmidecode | grep -A "Memory Device$"

       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

       sync

       # 释放前最好sync一下,防止丢数据。因为LINUX的内核机制,一般情况下不需要特意去释放已经使用的cache。这些cache起来的内容可以增加文件以及的读写速度。

       # 先说下free命令怎么看内存

       代码如下:

       $free

       total used free shared buffers cached

       Mem: 0

       -/+ buffers/cache:

       Swap: 0 0 0

       # 第一行用全局角度描述系统使用的内存状况:

       total——总物理内存

       used——已使用内存,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存

       free——完全未被使用的内存

       shared——应用程序共享内存

       buffers——缓存,主要用于目录方面,inode值等(ls大目录可看到这个值增加)

       cached——缓存,用于已打开的文件

       total = used + free

       used = buffers+cached (maybe add shared also)

       第二行描述应用程序的内存使用:

       前个值表示-buffers/cache——应用程序使用的内存大小,used减去缓存值

       后个值表示+buffers/cache——所有可供应用程序使用的内存大小,free加上缓存值

       -buffers/cache=used-buffers-cached

       +buffers/cache=free+buffers+cached

       第三行表示swap的使用:

       used——已使用

       free——未使用

       手动执行sync命令(描述:sync 命令运行 sync 子例程。如果必须停止系统,则运行 sync 命令以确保文件系统的完整性。sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件)

       echo 3 /proc/sys/vm/drop_caches

       cat /proc/sys/vm/drop_caches

       3

       !将/proc/sys/vm/drop_caches值设为3

       # 有关/proc/sys/vm/drop_caches的用法在下面进行了说明

       代码如下:

       /proc/sys/vm/drop_caches (since Linux 2.6.)

       Writing to this file causes the kernel to drop clean caches,

       dentries and inodes from memory, causing that memory to become

       free.

       To free pagecache, use echo 1 /proc/sys/vm/drop_caches; to

       free dentries and inodes, use echo 2 /proc/sys/vm/drop_caches;

       to free pagecache, dentries and inodes, use echo 3

       /proc/sys/vm/drop_caches.

       Because this is a non-destructive operation and dirty objects

       # 原文链接:http://levi.cg.am/?p=

linux free命令

       Linux系统中的free命令提供了一种直观的方式来查看内存和交换分区的使用情况。它主要关注物理内存(Mem)和硬盘交换分区(Swap)的统计信息。

       首先,free命令显示的Mem部分,total列代表物理内存的总量,used则是已分配给缓存(包括buffers和cache)的内存,尽管有些可能并未实际使用。free列是未分配的内存,这部分内存可供系统即时使用。shared内存通常较少见,libzmp源码这里不做讨论。buffers是系统预留但未被使用的内存,而cached则是系统已分配但未被使用的缓存。

       在第二行的-/+ buffers/cached中,used列显示的是第一行中used减去buffers和cached,即实际被系统占用的内存总量。free列则是未使用的buffers和cache,加上未被分配的内存,构成了系统当前的实际可用内存。

linuxfree命令详解linuxfree命令

       Linux中cat/etc/issue和lsb_release命令显示的结果会不同么?

       æ˜¯ä¸åŒçš„。

       1、/etc/issue和/etc/redhat-release都是系统安装时默认的发行版本信息,通常安装好系统后文件内容不会发生变化。

       2、lsb_release-a:FSG(FreeStandardsGroup)组织开发的LSB(LinuxStandardBase)标准的一个命令,用来查看linux兼容性的发行版信息。

       3、/proc/version和uname-a显示的内容相同,显示linux内核版本号。lsb_release参数:

       free是什么文件?

       RAM,电脑上已经使用的内存,Free,就是空闲的内存。

       free

       linux命令:查看当前系统内存的使用情况,它显示系统中剩余及已用的物理内存和交换内存,以及共享内存和被核心使用的缓冲区。

       æ ¼å¼ï¼šfree

       å‘½ä»¤ä¸­å„个选项的含义:

       -b:以字节为单位显示。

       -k:以K字节为单位显示。

       -m:以兆字节为单位显示。

       linux系统空间怎么查看?

       linux查看占用空间

       1、打开linux系统,在linux的桌面的空白处右击。

       2、在弹出的下拉选项里,点击打开终端。

       3、在终端窗口中输入free命令,回车后即可查看到系统资源的使用情况。

       total:总计物理内存的大小

       used:已使用多大

       free:可用有多少

       Shared:多个进程共享的内存总额

       Buffers/cached:磁盘缓存的大小

       linux常用命令有哪些?

       Linux是我们开发人员必不可少的系统,也是经常接触到的。然而,Linux命令比较多,有些不常用也难记住。那么,我们如何更高效的使用Linux命令,而又不必全面地学习呢?今天就给大家分享一下我在开发过程中,比较常用、也比较实用的Linux命令。

       æŸ¥çœ‹æ–‡ä»¶æˆ–日志

       æŸ¥çœ‹æ–‡ä»¶å†…容或日志文件,相信几乎所有人都会接触到。其中,用得最多的就是head、tail和cat命令。

       1、head

       è¡¨ç¤ºå¤´éƒ¨ï¼ŒæŸ¥çœ‹æœ€å‰é¢å‡ è¡Œæ•°æ®ã€‚

       headtest.log:test.log文件前几行日志内容

       head-ntest.log:查看test.log文件前行日志内容

       head-n-test.log:查看test.log除了最后行日志内容

       2、tail

       è¡¨ç¤ºå°¾éƒ¨ï¼ŒæŸ¥çœ‹æœ€åŽå‡ è¡Œæˆ–实时日志。

       tail-ftest.log:实时查看test.log文件最后几行日志内容

       tail-f-ntest.log:实时查看test.log文件最后行日志内容

       tail-ntest.log:查看test.log文件最后行日志内容

       tail-n+test.log:查看test.log文件行后的所有日志内容

       3、cat

       ç”¨äºŽæŸ¥çœ‹æ–‡ä»¶å†…容。

       cattest.log:查看test.log文件所有内容

       æœ¬åœ°å¤åˆ¶

       åŒä¸€å°æœåŠ¡å™¨ä¸åŒç›®å½•ä¹‹é—´å¤åˆ¶æ–‡ä»¶æˆ–目录也是经常用到的。

       1、复制文件

       cptest.log/home/geshan/logs:复制test.log文件到/home/geshan/logs/目录下

       cptest.log/home/geshan/logs/cptest.log:复制test.log文件到/home/geshan/logs/目录下并重新命名为cptest.log

       2、复制文件夹

       cp-rlogs//home/geshan/:复制logs目录及目录下所有文件到/home/geshan/目录下,此时该目录会有logs目录

       cp-rlogs//home/geshan/testlogs/:复制logs目录及目录下所有文件到/home/geshan/testlogs/目录下,并把logs目录重新命名为testlogs,前提是/home/geshan/目录没有testlogs目录

       æ³¨ï¼š-r或-R表示循环,循环目录下所有文件和目录。下面所有命令也是如此。

       è¿œç¨‹å¤åˆ¶

       å½“我们需要从远程服务器复制某个文件或目录到本地登录的服务器时,大部分人想到先登录远程服务器下载该文件,然后再登录本地服务器再上传文件。这样是比较麻烦,效率也不高。

       1、本地服务器复制到远程服务器

       (1)复制文件

       å‘½ä»¤1:

       scplocal_fileremote_username@remote_ip:remote_folder

       å‘½ä»¤2:

       scplocal_fileremote_username@remote_ip:remote_file

       å‘½ä»¤3:

       scplocal_fileremote_ip:remote_folder

       å‘½ä»¤4:

       scplocal_fileremote_ip:remote_file

       ç¬¬1,2个指定了用户名,命令执行后需要输入用户密码,第1个仅指定了远程的目录,文件名字不变;第2个指定了文件名;第3,4个没有指定用户名,命令执行后默认与当前服务器用户名并需要输入用户密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名。

       å®žä¾‹1:从本地服务器复制test.log至...服务器的/home/geshan/目录,并重新命名为

       .log

       å‘½ä»¤ï¼š

       å®žä¾‹2:从本地服务器复制test.log至...服务器的/home/geshan/目录

       å‘½ä»¤ï¼š

       (2)复制目录

       å‘½ä»¤1:

       scp-rlocal_folderremote_username@remote_ip:remote_folder

       å‘½ä»¤2:

       scp-rlocal_folderremote_ip:remote_folder

       ç¬¬1个指定了用户名,命令执行后需要输入用户密码;第2个没有指定用户名,命令执行后需要输入用户名和密码。

       å®žä¾‹ï¼šä»Žæœ¬åœ°æœåŠ¡å™¨/home/appuser/目录下的tomcat目录复制到...服务器的/home/geshan/目录命令:

       2、从远程服务器复制到本地服务器

       ä»Žè¿œç¨‹å¤åˆ¶åˆ°æœ¬åœ°çš„scp命令与上面的命令雷同,只要将从本地复制到远程的命令后面2个参数互换顺序就行了。

       (1)复制文件

       å®žä¾‹ï¼š

       ä»Ž...远程服务器的/home/geshan/路径下test.log文件复制到本地服务器/home/appuser/路径

       å‘½ä»¤ï¼š

       scproot@...:/home/geshan/test.log/home/appuser/

       (2)复制目录

       å®žä¾‹ï¼šä»Ž...远程服务器的/home/geshan/路径下tomcat文件夹复制到本地服务器/home/appuser/路径

       å‘½ä»¤ï¼š

       æ³¨ï¼šip地址和路径之间(即冒号之间)没有任何空格,否则会报错。当第一次和另外一台服务通信(如复制文件),会提示是否信任,输入yes即可。

       åŽ‹ç¼©å’Œè§£åŽ‹

       åŽ‹ç¼©å’Œè§£åŽ‹æ–‡ä»¶ä¹Ÿæ˜¯ç»å¸¸é‡åˆ°çš„。如果下载一个目录下的所有文件,可以直接下载这个目录,但是直接下载目录的话,文件一旦很多,下载过程中很容易丢失文件,下载速度也比较慢。一般情况下是先压缩文件夹再下载。下面给大家介绍四种压缩和解压命令。

       1、tar命令

       è§£åŽ‹ï¼š

       åŽ‹ç¼©ï¼š

       å®žä¾‹ï¼šè§£åŽ‹ä¸€ä¸ªlog.tar文件:

       åŽ‹ç¼©log目录并命名为log.tar:

       2、gz命令

       åŽ‹ç¼©ï¼š

       æ³¨ï¼šåŽ‹ç¼©ä¸º.gz文件源文件会消失如果想保留源文件,使用下面命令

       è§£åŽ‹ï¼š

       .tar.gz和.tgz解压:

       åŽ‹ç¼©ï¼š

       åŽ‹ç¼©å¤šä¸ªæ–‡ä»¶ï¼š

       å®žä¾‹ï¼šè§£åŽ‹tomcat.tar.gz文件

       åŽ‹ç¼©tomcat目录,并命名为tomcat.tar.gz文件

       3、zip命令

       è§£åŽ‹ï¼šunzipfileName.zip压缩:

       æ³¨ï¼šåŽ‹ç¼©ç›®å½•æ—¶ï¼Œéœ€åŠ -r,表示循环该目录下所有文件和目录。压缩多个文件或目录时,文件或目录之间需要空格。

       å®žä¾‹ï¼šè§£åŽ‹ä¸€ä¸ªlog.zip文件:

       åŽ‹ç¼©log文件目录并命名为log.zip:

       åŽ‹ç¼©log1和log2目录并命名为log.zip:

       åŽ‹ç¼©test1.log和test2.log文件并命名为log.zip:

       4、rar命令

       åŒç†ï¼Œå’Œzip命令类似,只需把zip改为rar即可。

       ä¿®æ”¹æƒé™

       Linux系统中文件和目录访问权限是不同的,通过些方式可以确定谁可以对该文件和目录进行相应的操作。

       å…¶ä¸­ï¼Œæ–‡ä»¶æˆ–目录的访问权限分为只读,只写和可执行三种,分别代表可读、可写和可执行。

       1、chgrp命令

       æ”¹å˜æ–‡ä»¶æˆ–目录所属的组。命令:

       å®žä¾‹ï¼šæŠŠtest.log文件所属的组修改为geshan组

       æŠŠlogs目录及该目录下所有文件所属的组修改为geshan组

       2、chown命令

       æ›´æ”¹æŸä¸ªæ–‡ä»¶æˆ–目录所属的用户。命令:

       å®žä¾‹ï¼šæŠŠtest.log文件所属用户修改为geshan用户

       æŠŠlogs目录及该目录下所有文件所属用户修改为geshan用户

       3、chmod命令

       ç”¨äºŽæ”¹å˜æ–‡ä»¶æˆ–目录的访问权限。用户用它控制文件或目录的访问权限。命令:

       å…¶ä¸­ï¼Œmode有很多种表示含义,下面只对数字说明。大部分人看到mode有或等权限,这些表示什么呢?

       ä¸ºäº†æ–¹ä¾¿ï¼ŒæŠŠmode改为abc,其中a,b,c各为一个数字,分别表示user、group及other的权限。r=4,w=2,x=1,r表示Read读,w表示Write写,x表示eXecute。

       è‹¥è¦rwx属性则4+2+1=7;

       è‹¥è¦rw-属性则4+2=6;

       è‹¥è¦r-x属性则4+1=5。

       å®žä¾‹ï¼šæŠŠtest.log文件修改可读写执行(即)操作。

       æŠŠlogs目录及目录下所有文件修改为读写()操作。

       åœ¨Linux系统中输入ll(两个小写LL),如果文件或目录为(读写执行)权限,可看到最前面为-rwxrwxrwx。如果为(读写)权限,可看到最前面为-rw-rw-rw。

       æ³¨ï¼šä¸€èˆ¬ä¿®æ”¹æ–‡ä»¶æˆ–目录权限需要超级用户(root)进行修改,否则可能会报权限不足。

       è¿™äº›Linux命令是比较常用实用的命令,肯定会有用得到的时候,如果对你有所帮助,记得点赞收藏转发哦!

       linux怎样看内存的时候换单位?

       Linux查看剩余可用内存用free-m命令,-m选项表示用MB为单位显示容量(如果是以GB为单位就换成-g选项),显示的结果里面used那一列是已经使用的量,free那一列就是剩余内存大小了。

free 命令示例 | Linux 中国

       Linux中的free命令能帮助你深入了解系统的内存(RAM)使用情况,以及是否启用了交换。下面将演示如何高效利用这个命令。

       要使用free命令,无需复杂的步骤。只需在终端输入命令即可。

       free命令的语法如下:

       有多个选项可调整命令行为。接下来,分享一些常用的free命令选项。

       不带任何选项的free命令输出如下:

       这里显示了内存的详细信息,包括总内存、已用内存、可用内存、缓冲区和缓存大小等。如果你希望以更易读的格式显示数据,可以使用-h选项:

       此选项将以人类可读的形式(如KB或GB)显示值。

       想要连续显示统计数据?可以使用-s选项,以特定时间间隔刷新信息。例如:

       此命令将每秒刷新一次统计信息。

       若需控制刷新次数,可以使用-c选项:

       命令将刷新指定次数的统计信息。

       若想自定义输出数据类型,可以使用以下标志:

       例如,以MB为单位显示内存统计信息的命令如下:

       若要获取物理内存和交换内存的总和,可以使用-t选项:

       至此,已详细介绍了free命令的使用方法,包括如何以人类可读形式显示信息、连续刷新统计数据、定义刷新次数、指定输出数据类型及获取内存总和。接下来,请尝试以下练习题:

       练习题:

       以人类可读形式显示内存信息。

       每秒刷新一次统计信息。

       显示统计数据3次。

       以MB为单位显示内存统计信息。

       获取物理内存和交换内存的总和。

       希望这些练习能帮助你熟练掌握free命令。如果你有任何疑问,欢迎在评论区提问。此外,如果你对接下来的内容有任何建议,请分享你的想法。感谢阅读,期待你的反馈!

linux free命令详解和使用实例

       1.命令格式:

       free [参数]

2.命令功能:

       free 命令显示系统使用和空闲的内存情况,包括物理内存、交互区内存(swap)和内核缓冲区内存。共享内存将被忽略

3.命令参数:

       -b 以Byte为单位显示内存使用情况。

       -k 以KB为单位显示内存使用情况。

       -m 以MB为单位显示内存使用情况。

       -g   以GB为单位显示内存使用情况。

       -o 不显示缓冲区调节列。

       -s间隔秒数 持续观察内存使用状况。

       -t 显示内存总和列。

       -V 显示版本信息。

4.使用实例:

       实例1:显示内存使用情况

       命令:

       复制代码

           

       代码如下:

       free

           free -g

           free -m

       输出:

       复制代码

           

       代码如下:

       [root@SF service]# free

           total used free shared buffers cached

           Mem: 0

           -/+ buffers/cache:

           Swap: /pp

           [root@SF service]# free -g

           total used free shared buffers cached

           Mem: 2 0 4

           -/+ buffers/cache:

           Swap: 1 /pp

           [root@SF service]# free -m

           total used free shared buffers cached

           Mem: 0

           -/+ buffers/cache:

           Swap:

free命令输出内容详细说明:

       下面是对这些数值的解释:

       total:总计物理内存的大小。

       used:已使用多大。

       free:可用有多少。

       Shared:多个进程共享的内存总额。

       Buffers/cached:磁盘缓存的大小。

       第三行(-/+ buffers/cached):

       used:已使用多大。

       free:可用有多少。

       第四行是交换分区SWAP的,也就是我们通常所说的虚拟内存。

       区别:第二行(mem)的used/free与第三行(-/+ buffers/cache) used/free的区别。 这两个的区别在于使用的角度来看,第一行是从OS的角度来看,因为对于OS,buffers/cached 都是属于被使用,所以他的可用内存是KB,已用内存是KB,其中包括,内核(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.

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

       所以从应用程序的角度来说,可用内存=系统free memory+buffers+cached。

       如本机情况的可用内存为:

       =KB+KB+KB

       接下来解释什么时候内存会被交换,以及按什么方交换。

       当可用内存少于额定值的时候,就会开会进行交换.如何看额定值:

       命令:cat /proc/meminfo

       输出:

       复制代码

           

       代码如下:

       [root@SF service]# cat /proc/meminfo

           MemTotal: kB

           MemFree: kB

           Buffers: kB

           Cached: kB

           SwapCached: kB

           Active: kB

           Inactive: kB

           HighTotal: 0 kB

           HighFree: 0 kB

           LowTotal: kB

           LowFree: kB

           SwapTotal: kB

           SwapFree: kB

           Dirty: kB

           Writeback: 0 kB

           AnonPages: kB

           Mapped: kB

           Slab: kB

           PageTables: kB

           NFS_Unstable: 0 kB

           Bounce: 0 kB

           CommitLimit: kB

           Committed_AS: kB

           VmallocTotal: kB

           VmallocUsed: kB

           VmallocChunk: kB

           HugePages_Total: 0HugePages_Free: 0HugePages_Rsvd: 0Hugepagesize: kB

       交换将通过三个途径来减少系统中使用的物理页面的个数:

       1.减少缓冲与页面cache的大小,

       2.将系统V类型的内存页面交换出去,

       3.换出或者丢弃页面。(Application 占用的内存页,也就是物理内存不足)。

       事实上,少量地使用swap是不是影响到系统性能的。

       那buffers和cached都是缓存,两者有什么区别呢?

       为了提高磁盘存取效率, Linux做了一些精心的设计, 除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换), 还采取了两种主要Cache方式:Buffer Cache和Page Cache。前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache有效缩短了 I/O系统调用(比如read,write,getdents)的时间。

       磁盘的操作有逻辑级(文件系统)和物理级(磁盘块),这两种Cache就是分别缓存逻辑和物理级数据的。

       Page cache实际上是针对文件系统的,是文件的缓存,在文件层面上的数据会缓存到page cache。文件的逻辑层需要映射到实际的物理磁盘,这种映射关系由文件系统来完成。当page cache的数据需要刷新时,page cache中的数据交给buffer cache,因为Buffer Cache就是缓存磁盘块的。但是这种处理在2.6版本的内核之后就变的很简单了,没有真正意义上的cache操作。

       Buffer cache是针对磁盘块的缓存,也就是在没有文件系统的情况下,直接对磁盘进行操作的数据会缓存到buffer cache中,例如,文件系统的元数据都会缓存到buffer cache中。

       简单说来,page cache用来缓存文件数据,buffer cache用来缓存磁盘数据。在有文件系统的情况下,对文件操作,那么数据会缓存到page cache,如果直接采用dd等工具对磁盘进行读写,那么数据会缓存到buffer cache。

       所以我们看linux,只要不用swap的交换空间,就不用担心自己的内存太少.如果常常swap用很多,可能你就要考虑加物理内存了.这也是linux看内存是否够用的标准.

       如果是应用服务器的话,一般只看第二行,+buffers/cache,即对应用程序来说free的内存太少了,也是该考虑优化程序或加内存了。

       实例2:以总和的形式显示内存的使用信息

       命令:free -t

       输出:

       复制代码

           

       代码如下:

       [root@SF service]# free -t

           total used free shared buffers cached

           Mem: 0

           -/+ buffers/cache: Swap: Total: [root@SF service]#

       说明:

       实例3:周期性的查询内存使用信息

       命令:free -s

       输出:

       复制代码

           

       代码如下:

       [root@SF service]# free -s

           total used free shared buffers cached

           Mem: 0

           -/+ buffers/cache: Swap:

           total used free shared buffers cached

           Mem: 0

           -/+ buffers/cache: Swap:

       说明:

       每s 执行一次命令

详细解读Linux内核存储性能观测中的free命令

       概要:free命令报告系统内存使用情况,包括实体内存、虚拟交换文件内存、共享内存区段以及系统核心缓冲区信息。这些数据从/proc/meminfo收集。

       安装方式:procps软件包包含/proc目录信息以监控和终止系统进程。

       参数说明:free命令选项区分大小写。

       输出说明:(-/+ buffers/cache)分别表示被程序占用的真实内存和可重用总内存。

       观测分析:Linux通过缓存优化磁盘和内存存取效率,包括dentry缓存、Buffer Cache和Page Cache,有效缩短I/O时间。

       内存释放:Linux将暂时不用的内存转为缓存,提高运行效率。内存释放通过sync命令确保文件系统完整性。

       内存管理:/proc文件系统提供实时内存数据。内存管理策略在/proc/sys/vm/drop_chches文件中表示,内容仅为0-3数字,代表系统含义。

       举例:在生产环境中,应优化应用程序内存利用,而非频繁清理内存,重点在程序调优。

       英文说明:资料来源于博客文章(链接需审核,若涉及版权问题,请删除)。

       往期精彩回顾:包含多个技术文章链接,涉及Linux系统性能分析工具、CPU使用率查看、内核链表、流量控制等主题。

更多内容请点击【知识】专栏