2017-05-25 100 views
0

我的VMware客戶系統細節:預訂Linux系統上的大頁面

Linux 2.6.32-358.el6.x86_64 (RH 6.4 - Santiago) 

# cat /proc/meminfo 
MemTotal:  8058796 kB 
MemFree:   5145692 kB 
Buffers:   32320 kB 
Cached:   291312 kB 
SwapCached:   0 kB 
Active:   1524652 kB 
Inactive:   192444 kB 
Active(anon): 1393628 kB 
Inactive(anon):  1196 kB 
Active(file):  131024 kB 
Inactive(file): 191248 kB 
Unevictable:   0 kB 
Mlocked:    0 kB 
SwapTotal:  4063224 kB 
SwapFree:  4063224 kB 
Dirty:    144 kB 
Writeback:    0 kB 
AnonPages:  1393488 kB 
Mapped:   47288 kB 
Shmem:    1364 kB 
Slab:    52080 kB 
SReclaimable:  18572 kB 
SUnreclaim:  33508 kB 
KernelStack:  3776 kB 
PageTables:  15864 kB 
NFS_Unstable:   0 kB 
Bounce:    0 kB 
WritebackTmp:   0 kB 
CommitLimit:  4063224 kB 
Committed_AS: 3101408 kB 
VmallocTotal: 34359738367 kB 
VmallocUsed:  160248 kB 
VmallocChunk: 34359572656 kB 
HardwareCorrupted:  0 kB 
AnonHugePages:   0 kB 
HugePages_Total:  512 
HugePages_Free:  240 
HugePages_Rsvd:  240 
HugePages_Surp:  0 
Hugepagesize:  2048 kB 
DirectMap4k:  10240 kB 
DirectMap2M:  8378368 kB 

grub contents: 
transparent_hugepage=never default_hugepagesz=2M hugepagesz=2M hugepages=512 

# sysctl -a | grep vm 
vm.overcommit_memory = 0 
vm.panic_on_oom = 0 
vm.oom_kill_allocating_task = 0 
vm.extfrag_threshold = 500 
vm.oom_dump_tasks = 1 
vm.would_have_oomkilled = 0 
vm.overcommit_ratio = 0 
vm.page-cluster = 3 
vm.dirty_background_ratio = 10 
vm.dirty_background_bytes = 0 
vm.dirty_ratio = 20 
vm.dirty_bytes = 0 
vm.dirty_writeback_centisecs = 500 
vm.dirty_expire_centisecs = 3000 
vm.nr_pdflush_threads = 0 
vm.swappiness = 60 
vm.nr_hugepages = 512 
vm.nr_hugepages_mempolicy = 512 
vm.hugetlb_shm_group = 0 
vm.hugepages_treat_as_movable = 0 
vm.nr_overcommit_hugepages = 0 
vm.lowmem_reserve_ratio = 256 256  32 
vm.drop_caches = 0 
vm.min_free_kbytes = 2048 
vm.extra_free_kbytes = 0 
vm.percpu_pagelist_fraction = 0 
vm.max_map_count = 65530 
vm.laptop_mode = 0 
vm.block_dump = 0 
vm.vfs_cache_pressure = 100 
vm.legacy_va_layout = 0 
vm.zone_reclaim_mode = 0 
vm.min_unmapped_ratio = 1 
vm.min_slab_ratio = 5 
vm.stat_interval = 1 
vm.mmap_min_addr = 4096 
vm.numa_zonelist_order = default 
vm.scan_unevictable_pages = 0 
vm.memory_failure_early_kill = 0 
vm.memory_failure_recovery = 1 

我的應用程序需要,因爲它可以在啓動時,但HugePages_Free等於HugePages_Rsvd的事實意味着它抓住儘可能多的大內存頁無法預約。

這是什麼原因,以及如何禁用其他應用程序保留的巨大頁面,如果有的話?

感謝

回答

0

,這是什麼原因,以及如何我被其他應用程序禁用大頁面的保留,如果有任何?

原因是Linux使用巨大頁面進行分配和內存映射。請看看mmmap(2)(MAP_HUGETLB標誌),madvice(2)(MADV_HUGEPAGE標誌)和透明大內存頁:

https://www.kernel.org/doc/Documentation/vm/transhuge.txt

所以基本上這樣做的原因是,您的系統上運行的任何應用程序可能會要求系統使用大量頁面,甚至Linux本身可能會將您的分配透明地放到大頁面上。 /啓用

所以禁用所有這些隱含的用途,你可能會考慮/ SYS /內核/ MM/transparent_hugepage

在另一方面,你可能會認爲是正確的應用程序開始之前,分配大內存頁。運行沒有任何大頁面的系統,然後配置它們:

echo 512 > /proc/sys/vm/nr_hugepages 

並立即運行您的應用程序。這將增加巨大頁面僅用於您的應用程序的可能性。

+0

在我的grub配置中,如上所列,THP被禁用: transparent_hugepage = never –

+0

此外,爲什麼免費頁數等於保留數? –