為什麼核心低記憶體區域小於 896 MB?

為什麼核心低記憶體區域小於 896 MB?

在我的系統中,內核的 Lowmem (NORMALZONE) 長度為 597424 kb。據我所知,最大應該是 890 MB 左右。為什麼這個系統要用 ~590 MB?是可調的嗎?
我問這個是因為,我面臨著此系統時常出現低記憶體 oom 狀況。所以我想使用盡可能大的lowmem。

Linux 3.10.24-2 #1 SMP 12 月 31 日星期二 07:09:19 EET 2013 i686 i686 i386 GNU/Linux

# free -lk
             total       used       free     shared    buffers     cached
Mem:      37426296    3369432   34056864          0      36048    1373524
Low:        597424     278236     319188
High:     36828872    3091196   33737676
-/+ buffers/cache:    1959860   35466436
Swap:     35318864          0   35318864



# cat /proc/meminfo
MemTotal:       37426296 kB
MemFree:        33971268 kB
Buffers:           36172 kB
Cached:          1383668 kB
SwapCached:            0 kB
Active:          2034844 kB
Inactive:        1036224 kB
Active(anon):    1656904 kB
Inactive(anon):    12716 kB
Active(file):     377940 kB
Inactive(file):  1023508 kB
Unevictable:           0 kB
Mlocked:               0 kB
HighTotal:      36828872 kB
HighFree:       33667168 kB
LowTotal:         597424 kB
LowFree:          304100 kB
SwapTotal:      35318864 kB
SwapFree:       35318864 kB
Dirty:                 0 kB
Writeback:             0 kB
AnonPages:       1653176 kB
Mapped:           138320 kB
Shmem:             18348 kB
Slab:             117464 kB
SReclaimable:      44796 kB
SUnreclaim:        72668 kB
KernelStack:        7704 kB
PageTables:        97184 kB
NFS_Unstable:          0 kB
Bounce:              116 kB
WritebackTmp:          0 kB
CommitLimit:    65259900 kB
Committed_AS:    3876084 kB
VmallocTotal:     122880 kB
VmallocUsed:       27020 kB
VmallocChunk:      23732 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
DirectMap4k:       10232 kB
DirectMap2M:      901120 kB

答案1

我不確定這次是否會被聽到,但無論如何我都會嘗試:切換到x86_64並不像您想像的那麼難。

但我想你仍然需要某種解釋。我建議,如果您只有 4G 內存,那麼 aLowTotal等於 ~850mb,對於 16G,它約為 ~750mb,對於 64G,它將等於 ~378mb。

讓我引用 Linux Torvalds

所有的低記憶體都用來struct page描述其他所有內容的陣列。

所以實際上解決你的問題的方法是減少伺服器擁有的內存量(物理上或可能透過mem啟動參數但我沒有檢查過)。
您也可以透過更改核心/用戶空間分割VMSPLIT_2G核心配置選項
但實際上,切換到 x86_64 更容易,不是嗎? =]

附言。實際上,您可以將 x86 使用者區與 x86_64 核心一起使用。

相關內容