符合中小企业对网站设计、功能常规化式的企业展示型网站建设
本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...
商城网站建设因基本功能的需求不同费用上面也有很大的差别...
手机微信网站开发、微信官网、微信商城网站...
Note:
Transparent Huge Pages are
not available on the 32-bit version of RHEL 6.
For RHEL 7 see
How to disable transparent hugepages (THP) on Red Hat Enterprise Linux 7
For RHEL 8 see
How to disable transparent hugepages (THP) on Red Hat Enterprise Linux 8
创新互联公司专业为企业提供德阳网站建设、德阳做网站、德阳网站设计、德阳网站制作等企业网站建设、网页设计与制作、德阳企业网站模板建站服务,十年德阳做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
Transparent Huge Pages (THP) are enabled by default in RHEL 6 for all applications. The kernel attempts to allocate hugepages whenever possible and any Linux process will receive 2MB pages if the mmap region is 2MB naturally aligned. The main kernel address space itself is mapped with hugepages, reducing TLB pressure from kernel code. For general information on Hugepages, see: What are Huge Pages and what are the advantages of using them?
The kernel will always attempt to satisfy a memory allocation using hugepages. If no hugepages are available (due to non availability of physically continuous memory for example) the kernel will fall back to the regular 4KB pages. THP are also swappable (unlike hugetlbfs). This is achieved by breaking the huge page to smaller 4KB pages, which are then swapped out normally.
But to use hugepages effectively, the kernel must find physically continuous areas of memory big enough to satisfy the request, and also properly aligned. For this, a khugepaged kernel thread has been added. This thread will occasionally attempt to substitute smaller pages being used currently with a hugepage allocation, thus maximizing THP usage.
In userland, no modifications to the applications are necessary (hence transparent). But there are ways to optimize its use. For applications that want to use hugepages, use of posix_memalign() can also help ensure that large allocations are aligned to huge page (2MB) boundaries.
Also, THP is only enabled for anonymous memory regions. There are plans to add support for tmpfs and page cache. THP tunables are found in the
/sys
tree under
/sys/kernel/mm/redhat_transparent_hugepage
.
The values for
/sys/kernel/mm/redhat_transparent_hugepage/enabled
can be one of the following:
always - always use THP never - disable THP
khugepaged will be automatically started when transparent_hugepage/enabled is set to "always" or "madvise, and it'll be automatically shutdown if it's set to "never". The redhat_transparent_hugepage/defrag parameter takes the same values and it controls whether the kernel should make aggressive use of memory compaction to make more hugepages available.
Run the following command to check system-wide THP usage:
# grep AnonHugePages /proc/meminfo AnonHugePages: 632832 kB
Note: Red Hat Enterprise Linux 6.2 or later publishes additional THP monitoring via
/proc/vmstat
:
# egrep 'trans|thp' /proc/vmstat nr_anon_transparent_hugepages 2018 thp_fault_alloc 7302 thp_fault_fallback 0 thp_collapse_alloc 401 thp_collapse_alloc_failed 0 thp_split 21
Run the following command to monitor which processes are using THP:
# grep -e AnonHugePages /proc/*/smaps | awk '{ if($2>4) print $0} ' | awk -F "/" '{print $0; system("ps -fp " $3)} ' /proc/7519/smaps:AnonHugePages: 305152 kB UID PID PPID C STIME TTY TIME CMD qemu 7519 1 1 08:53 ? 00:00:48 /usr/bin/qemu-system-x86_64 -machine accel=kvm -name rhel7 -S -machine pc-i440fx-1.6,accel=kvm,usb=of /proc/7610/smaps:AnonHugePages: 491520 kB UID PID PPID C STIME TTY TIME CMD qemu 7610 1 2 08:53 ? 00:01:30 /usr/bin/qemu-system-x86_64 -machine accel=kvm -name util6vm -S -machine pc-i440fx-1.6,accel=kvm,usb= /proc/7788/smaps:AnonHugePages: 389120 kB UID PID PPID C STIME TTY TIME CMD qemu 7788 1 1 08:54 ? 00:00:55 /usr/bin/qemu-system-x86_64 -machine accel=kvm -name rhel64eus -S -machine pc-i440fx-1.6,accel=kvm,us
Append the following to the kernel command line in
grub.conf
:
transparent_hugepage=never
Note: Certain ktune and/or tuned profiles specify to enable THP when they are applied. If the
transparent_hugepage=never
parameter is set at boot time, but THP does not appear to be disabled after the system is fully booted. Refer to the following article:
Disabling transparent hugepages (THP) on Red Hat Enterprise Linux 6 is not taking effect
Run the following commands to disable THP on-the-fly:
# echo never > /sys/kernel/mm/redhat_transparent_hugepage/enabled # echo never > /sys/kernel/mm/redhat_transparent_hugepage/defrag
transparent_hugepage=never
, this is due to the fact when THP is disabled at boot time, the value of
/sys/kernel/mm/redhat_transparent_hugepage/defrag
will not be changed, however this is expected and system will never go in THP defragmentation code path when it is disabled at boot and THP defrag need not to be disabled separately.There can be two types of HugePages in the system: Explicit Huge Pages which are allocated explicitly by
vm.nr_hugepages
sysctl parameter and Transparent Huge Pages which are allocated automatically by the kernel. See below on how to tell if Explicit HugePages is enabled or disabled.
Explicit HugePages DISABLED:
If the value of
HugePages_Total
is "0" it means HugePages is
disabled on the system.
# grep -i HugePages_Total /proc/meminfo HugePages_Total: 0
Similarly, if the value in
/proc/sys/vm/nr_hugepages
file or
vm.nr_hugepages
sysctl parameter is "0" it means HugePages is
disabled on the system:
# cat /proc/sys/vm/nr_hugepages # sysctl vm.nr_hugepages vm.nr_hugepages = 0
Explicit HugePages ENABLED:
If the value of
HugePages_Total
is greater than "0", it means HugePages is
enabled on the system:
# grep -i HugePages_Total /proc/meminfo HugePages_Total: 1024
Similarly if the value in
/proc/sys/vm/nr_hugepages
file or
vm.nr_hugepages
sysctl parameter is greater than "0", it means HugePages is
enabled on the system:
# cat /proc/sys/vm/nr_hugepages 1024 # sysctl vm.nr_hugepages vm.nr_hugepages = 1024