centos - 升级2G内存,可是查出来却不到2G,请问是不是被坑了?

【字号: 日期:2022-08-13浏览:54作者:雯心

问题描述

CentOS 64位升级2G内存,可是查出来却不到2G

$ free -m total used free shared buffers cachedMem: 1876605 1270 0 2 67-/+ buffers/cache:535 1340Swap: 0 0 0

请问是不是被坑了,如何在运营商面前发飙不被看出来很菜?

问题解答

回答1:

其实你装上2G的内存,能出来 total :1876就已经能证明是2g的内存了。。如果内存有问题,难道是3G的缩水到1876?

看的出来题主还是对1024那个算法不服,怎么就能算出来1876了呢 ?

请题主运行2个命令把结果贴出来1.cat /proc/meminfo |grep MemTotal2.free -b

我用4G的举例子(还真没有2G的机器)1.free -mtotal:3852 MB

1.free -b(这个单位是bytes!)total:4039471104 bytes

2.cat /proc/meminfo |grep MemTotal3944796 kB

3944796 kB*1024=4039471104bytes,和free -b结果是相同的

4039471104bytes / 1024=3944796 kB / 1024=3852.33984375MB

正如你看到的。。明白了吗?或者你运行这3个命令贴出来,算一下就知道了

回答2:

你没被坑,就是2G内存。制造商说的2GB,单位是Gigabyte,1GB等于1000^3 Byte我们平时说的GB,单位是Gibibyte,规范的缩写应该是GiB,等于1024^3 Byte所以会造成两边数据不一致。

准确的方法是:

dmidecode -t memory | grep ’Installed Size’

(grep的内容看发行版本不同而异,我是CentOS 6,不确定的可以不grep,直接看,就是内容比较多)

为什么说free -m不准:free命令是从/proc/meminfo中取数值展现,而/proc/meminfo中的MemTotal实际上是物理内存减去一些预留位和内核的二进制代码大小,所以是比物理内存要小写一些。

回答3:

free -m total used free shared buffers cachedMem: 488424 64 54 22205-/+ buffers/cache:196292Swap: 1999 0 1999

上面是我的一台阿里云主机,一样少了一些,现在服务商一般都说是1024和1000算法的不同引起,一般认为是正常的。买硬盘硬件时也一样。

回答4:

这个是2G的正常数值

如果你用redhat或其他发行版,可以用命令dmidecode,查看硬件信息

相关文章: