カーネルの低メモリゾーンが 896 MB 未満なのはなぜですか?

カーネルの低メモリゾーンが 896 MB 未満なのはなぜですか?

私のシステムではカーネルのLowmem(NORMALZONE)の長さは597424kbです。私が知る限り、最大で約890MBであるはずです。なぜこのシステムは590MBを使用するのでしょうか?これは調整可能ですか?
私がこれを尋ねているのは、このシステムでは時々メモリ不足状態になる. そのため、lowmem をできるだけ大きく使用したいと思います。

Linux 3.10.24-2 #1 SMP 2013年12月31日火曜日 07:09:19 EET 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 しかない場合はLowTotal約 850 MB、16G の場合は約 750 MB、64G の場合は約 378 MB になると思います。

私にさせてLinux Torvaldsを引用:

低メモリはすべて、struct pageその他すべてを記述する配列に使用されます。

実際のところ、この問題の回避策は減らすサーバーが持つメモリの量(物理的またはmemブートパラメータただし、確認していません。
また、カーネル/ユーザースペースの分割を変更することもできます。VMSPLIT_2Gカーネル設定オプションでも
実際、x86_64 に切り替えるほうが簡単ですよね? =]

PS. 実際には、x86_64 カーネルで x86 ユーザーランドを使用できます。

関連情報