linux – 为什么“free”命令和“dmidecode”显示不同的RAM值?

我在VMWare上运行了一个CentOS 5.10(32位)服务器.它分配了4 GB的RAM.

如果我运行dmidecode -t 17 | grep尺寸| grep MB我看到:

Size: 4096 MB

然而,当我自由奔跑时,我看到:

total       used       free     shared    buffers     cached
Mem:       3107140    1239244    1867896          0        332     400464
-/+ buffers/cache:     838448    2268692
Swap:      2096472          0    2096472

为什么无内存报告的总量与dmidecode输出之间存在差异?

我正在运行的内核是:

2.6.18-371.4.1.el5 #1 SMP Thu Jan 30 06:09:24 EST 2014 i686 i686 i386 GNU/Linux

不可否认,内核没有运行PAE,但我认为只有超过4 GB的内存才需要.

我知道我错过了一些简单的事情 – 有人可以详细说明吗?

附加说明/观察

看起来我的内核肯定会为其他东西保留一堆内存.这是我在/ var / log / dmesg中看到的内容:

Linux version 2.6.18-371.4.1.el5 (mockbuild@builder17.centos.org) (gcc version 4.1.2 20080704 (Red Hat 4.1.2-54)) #1 SMP Thu Jan 30 06:09:24 EST 2014
BIOS-provided physical RAM map:
 BIOS-e820: 0000000000010000 - 000000000009f800 (usable)
 BIOS-e820: 000000000009f800 - 00000000000a0000 (reserved)
 BIOS-e820: 00000000000ca000 - 00000000000cc000 (reserved)
 BIOS-e820: 00000000000dc000 - 0000000000100000 (reserved)
 BIOS-e820: 0000000000100000 - 00000000bfef0000 (usable)
 BIOS-e820: 00000000bfef0000 - 00000000bfeff000 (ACPI data)
 BIOS-e820: 00000000bfeff000 - 00000000bff00000 (ACPI NVS)
 BIOS-e820: 00000000bff00000 - 00000000c0000000 (usable)
 BIOS-e820: 00000000e0000000 - 00000000f0000000 (reserved)
 BIOS-e820: 00000000fec00000 - 00000000fec10000 (reserved)
 BIOS-e820: 00000000fee00000 - 00000000fee01000 (reserved)
 BIOS-e820: 00000000fffe0000 - 0000000100000000 (reserved)
 BIOS-e820: 0000000100000000 - 0000000140000000 (usable)
Warning only 4GB will be used.
Use a PAE enabled kernel.
3200MB HIGHMEM available.
896MB LOWMEM available.
found SMP MP-table at 000f6bf0
Memory for crash kernel (0x0 to 0x0) notwithin permissible range

解决方法

使用32位内核,您只有4GB的可用地址空间.其中一些地址空间必须由系统中的(虚拟或物理)硬件使用,例如视频卡,NIC等,以用于它们自己的目的.这种用法通常在256MB-1GB之间,具体取决于特定硬件需要多少地址空间.

由于该地址空间由硬件使用,因此32位系统通常无法访问相应的RAM.

你有几个选择:

>首选选项是运行64位操作系统.这大大扩展了地址空间,因此所有RAM和硬件都有足够的空间.它还打破了应用程序的2GB / 3GB 32位限制,同时保持了运行32位程序的能力.通常,任何具有2GB以上RAM的系统都应运行64位操作系统以避免这些问题.>另一种选择是在启用PAE的情况下运行32位内核.这将取消隐藏RAM,但每个进程仍将限制为2GB / 3GB的地址空间,具体取决于内核构建的细节.由于64位操作系统可以很好地运行32位应用程序,因此没有优势和许多缺点(例如缺少升级路径).

相关文章

linux常用进程通信方式包括管道(pipe)、有名管道(FIFO)、...
Linux性能观测工具按类别可分为系统级别和进程级别,系统级别...
本文详细介绍了curl命令基础和高级用法,包括跳过https的证书...
本文包含作者工作中常用到的一些命令,用于诊断网络、磁盘占满...
linux的平均负载表示运行态和就绪态及不可中断状态(正在io)的...
CPU上下文频繁切换会导致系统性能下降,切换分为进程切换、线...