Почему команда "free" и "dmidecode" показывают разные значения для RAM?

У меня есть сервер CentOS 5.10 (32-разрядный), работающий на VMWare. Выделено 4 ГБ оперативной памяти.

Если я бегу dmidecode -t 17 | grep Size | grep MB Я вижу:

Size: 4096 MB

Еще когда я бегу free, Я вижу:

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

Почему существует расхождение между общим объемом памяти free отчеты и 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 ГБ.

Я знаю, что упускаю что-то простое - кто-то может уточнить?

Дополнительные замечания / наблюдения

Похоже, мое ядро ​​резервирует кучу памяти для других вещей. Вот что я вижу в /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

3 ответа

Решение

С 32-битным ядром у вас есть только 4 ГБ доступного адресного пространства. Часть этого адресного пространства должна использоваться (виртуальным или физическим) оборудованием в системе, таким как видеокарты, сетевые карты и т. Д., Для своих собственных целей. Такое использование обычно составляет от 256 МБ до 1 ГБ в зависимости от того, сколько адресного пространства требуется конкретному оборудованию.

Поскольку это адресное пространство используется аппаратными средствами, соответствующая RAM обычно недоступна для 32-битной системы.

У вас есть несколько вариантов:

  1. Предпочтительным вариантом является запуск 64-битной операционной системы. Это значительно расширяет адресное пространство, поэтому в нем достаточно места для всей оперативной памяти и оборудования. Он также преодолевает 32-битный лимит в 2 ГБ /3 ГБ для приложений, сохраняя возможность запуска 32-битных программ. Как правило, любая система с 2 ГБ ОЗУ должна работать под управлением 64-разрядной ОС, чтобы избежать этих проблем.
  2. Другой вариант - запустить 32-битное ядро ​​с включенным PAE. Это покажет оперативную память, но каждый процесс будет по-прежнему ограничен 2 ГБ /3 ГБ адресного пространства, в зависимости от особенностей сборки ядра. Поскольку 64-разрядные ОС прекрасно работают с 32-разрядными приложениями, это не имеет никаких преимуществ и многих недостатков (таких как отсутствие пути обновления).

Выход из free Команда не считает зарезервированную память ядра и несколько других маленьких битов. Вы увидите это несоответствие даже в 64-битном ядре и даже с <2 ГБ ОЗУ.

Критическая строка из вашей физической карты ОЗУ такова:

 BIOS-e820: 0000000100000000 - 0000000140000000 (usable)

Эта строка показывает, что 1 ГБ (0x40000000 байт, шестнадцатеричный) физического ОЗУ вашей системы отображается BIOS выше предела 4 ГБ, что делает его недоступным для 32-разрядной системы без PAE.

Другие вопросы по тегам