
メモリ割り当てエラー(dmesgで報告)により、タブをほとんど開いていない通常のブラウジングや、gimpで画像処理をしているときでも、アプリが頻繁にクラッシュします。マシンには16GBのRAMが搭載されています。メモリ割り当てをテストしてみました。この質問:
$ stress-ng --vm-bytes $(awk '/MemAvailable/{printf "%d\n", $2 * 0.9;}' < /proc/meminfo)k --vm-keep -m 1
stress-ng: info: [28129] defaulting to a 86400 second (1 day, 0.00 secs) run per stressor
stress-ng: info: [28129] dispatching hogs: 1 vm
stress-ng: error: [28148] stress-ng-vm: gave up trying to mmap, no available memory
stress-ng: info: [28129] successful run completed in 10.02s
awk 行で 0.9 の代わりに 0.55 を使用すると、「使用可能なメモリがありません」というメッセージは返されませんが、0.55 より大きい値を使用するとエラーが発生します。使用可能なメモリを 0.55 以上割り当てることができないのはなぜですか?
これは/proc/meminfoの内容です
MemTotal: 15919800 kB
MemFree: 5488312 kB
MemAvailable: 12100632 kB
Buffers: 716568 kB
Cached: 6156352 kB
SwapCached: 0 kB
Active: 5465468 kB
Inactive: 4214576 kB
Active(anon): 2985580 kB
Inactive(anon): 117944 kB
Active(file): 2479888 kB
Inactive(file): 4096632 kB
Unevictable: 176576 kB
Mlocked: 2476 kB
SwapTotal: 999420 kB
SwapFree: 999420 kB
Dirty: 156 kB
Writeback: 0 kB
AnonPages: 2983852 kB
Mapped: 713212 kB
Shmem: 294288 kB
KReclaimable: 380216 kB
Slab: 448228 kB
SReclaimable: 380216 kB
SUnreclaim: 68012 kB
KernelStack: 14432 kB
PageTables: 55080 kB
NFS_Unstable: 0 kB
Bounce: 0 kB
WritebackTmp: 0 kB
CommitLimit: 16760020 kB
Committed_AS: 9543584 kB
VmallocTotal: 34359738367 kB
VmallocUsed: 31412 kB
VmallocChunk: 0 kB
Percpu: 2848 kB
HardwareCorrupted: 0 kB
AnonHugePages: 0 kB
ShmemHugePages: 0 kB
ShmemPmdMapped: 0 kB
FileHugePages: 0 kB
FilePmdMapped: 0 kB
HugePages_Total: 0
HugePages_Free: 0
HugePages_Rsvd: 0
HugePages_Surp: 0
Hugepagesize: 2048 kB
Hugetlb: 0 kB
DirectMap4k: 274432 kB
DirectMap2M: 9728000 kB
DirectMap1G: 6291456 kB
以下は私のオーバーコミット設定です:
$ cat /proc/sys/vm/overcommit_memory
2
$ cat /proc/sys/vm/overcommit_ratio
99
$ cat /proc/sys/vm/swappiness
10
答え1
使用している厳格なオーバーコミット計算なので、プロセスは使用可能なメモリを超えてマップすることはできません。 のCommitted_AS
行は、現在 9543584 kiB が割り当てられていることを示しており、 のCommitLimit
行は、制限が 16760020 kiB であり、割り当て可能な残り 7216436 kiB であることを示しています。これは使用可能なメモリの 59.6% です。そのため、 のオーバーヘッドを考慮するとstress-ng
、使用可能なメモリの 55% 以上を vm ワーカーに割り当てることができないのはそれほど驚くことではありません。
stress-ng
使用可能なメモリをさらに割り当てられるようにしたい場合は、オーバーコミットを許可する必要があります。
sudo sysctl vm.overcommit_memory=0
または、スワップの量を増やしてコミット制限を上げます。