3 easy steps to configure hugepages in RHEL/CentOS 7/8


Tips and Tricks, How To, Linux

In this article I will share the steps to configure hugepages and also create hugepages pool to allot pages to the application based on the request in Red Hat and CentOS 7 Linux. We will configure hugepages using hugeadm tool

 

 

Configure hugepages in Red Hat/CentOS 7/8

We can configure hugepages by using the kernel tunable vm.nr_hugepages

Step 1: Check huge pages status

Check the existing value of vm.nr_hugepages

[root@centos8 ~]# sysctl -a | grep vm.nr_hugepages
vm.nr_hugepages = 0

So looks like vm.nr_hugepages is disabled in my CentOS 8 server.

Anyhow these topics are not the agenda here, we know our hugepages are disabled so we will enable and configure hugepages for 2048 so we will reserve 2MB of hugepages memory in the kernel

 

Step 2: Update vm.nr_hugepages in /etc/sysctl.conf

Edit /etc/sysctl.conf file to configure hugepages and specify the number of hugepages in the vm.nr_hugepages :

vm.nr_hugepages = 2048

 

Step 3: Refresh kernel parameters

Next we must refresh the kernel parameters using sysctl -p to activate the new hugepages value

[root@centos8 ~]# sysctl -p

Verify the new hugepage reservation

[root@centos8 ~]# sysctl -a | grep vm.nr_hugepages
vm.nr_hugepages = 2048

 

Step 4: Reboot

  • In one way we can say that a reboot is not mandatory but strongly recommended. Because we know that vm.nr_hugepages is now showing us the new reservation.
  • But since the provided amount of memory must be reserved by the kernel we have to make sure that there are enough contiguous memory available for reservation
  • You can read more at : Beginners guide to Linux memory Management in Linux
  • This is only possible at early boot up stage when none of the applications or system process would be using the system memory and kernel can easily allot provided value for hugepages
  • Hence a reboot is strongly recommended in production environment after you configure hugepages
[root@centos8 ~]# systemctl reboot

 

Configure hugepages pool in Red Hat/CentOS 7

  • The hugeadm utility is provided by package libhugetlbfs-utils and can be used to displays and configures the systems huge page pools.
  • The size of the pools is set as a minimum and maximum threshold.
  • The minimum value is allocated up front by the kernel and guaranteed to remain as hugepages until the pool is shrunk.
  • If a maximum is set, the system will dynamically allocate pages if applications request more hugepages than the minimum size of the pool.
  • There is no guarantee that more pages than this minimum pool size can be allocated.

 

Step 1: Install libhugetlbfs-utils

The hugeadm utility is provided by package libhugetlbfs-utils and can be used to displays and configures the systems huge page pools. The size of the pools is set as a minimum and maximum threshold.

Execute the following command to install libhugetlbfs-utils package.

NOTE:
On RHEL system you must have an active subscription to RHN or you can configure a local offline repository using which "yum" package manager can install the provided rpm and it's dependencies.
# yum -y install libhugetlbfs libhugetlbfs-utils

 

Step 2: Check supported HugePage Size

Before we configure hugepages pool, list all page sizes supported by the system, even if no pool is available

# hugeadm --page-sizes-all
2097152
1073741824

So currently our Red Hat and CentOS 7 server supportshugepage size of 2MB and 1GB

This command displays every page size supported by the system and has a pool configured

# hugeadm --page-sizes
2097152

So currently our server is configured to use 2MB hugepage size.
You can also get this information from /proc/cpuinfo. You should also know how to check if your CPU supports hugepages

# grep Hugepagesize /proc/meminfo
Hugepagesize:       2048 kB

Below command displays all active mount points for hugetlbfs

# hugeadm --list-all-mounts
Mount Point          Options
/dev/hugepages       rw,relatime

This displays the Minimum, Current and Maximum number of huge pages in the pool for each pagesize supported by the system.

  • The minimum value is allocated up front by the kernel and guaranteed to remain as hugepages until the pool is shrunk.
  • If a maximum is set, the system will dynamically allocate pages if applications request more hugepages than the minimum size of the pool.
  • There is no guarantee that more pages than this minimum pool size can be allocated.
  • Since our hugepage size is 2MB you can see the hugepage pool for 2097152 while for the other hugepage size, no pools are configured
# hugeadm --pool-list
      Size  Minimum  Current  Maximum  Default
   2097152    12850    12850    12850        *
1073741824        0        0        0

Here,

Minimum -	This is the size of the static pool and there will always be at 
			least this number of hugepages in use by the system, either by 
			applications or kept by the kernel in a reserved  pool.  
			
Current -	This value is the number of hugepages currently in use, either 
			by applications or stored on the kernels free list. 
			
Maximum -	This value is the largest number of hugepages that can be in 
			use at any given time.

 

Step 2: Configure HugePages using hugeadm

The (--pool-pages-min) option sets or adjusts the Minimum number of hugepages in the pool for pagesize size. size may be specified in bytes or in kilobytes, megabytes, or gigabytes by appending K, M, or G respectively, or as DEFAULT, which uses the system's default huge page size for size.

Here we are setting 4096 as the minimum number of pages for 2MB HugePage.

# hugeadm --pool-pages-min 2MB:4096

 

The (--pool-pages-max) option sets or adjusts the Maximum number of hugepages.
NOTE: While the Minimum number of pages are guaranteed to be available to applications, there is not guarantee that the system can allocate the pages on demand when the number of huge pages requested by applications is between the Minimum and Maximum pool sizes.

# hugeadm --pool-pages-max 2MB:12850

 

Step 3: Verify the new hugepages pool

Verify the pool list again

# hugeadm --pool-list
      Size  Minimum  Current  Maximum  Default
   2097152     4096     4096    12850        *
1073741824        0        0        0

 

Lastly I hope the steps from the article to Configure HugePages and hugepages pool using hugeadm command in Linux was helpful. So, let me know your suggestions and feedback using the comment section.

 

References:
How to configure hugepages using vm.nr_hugepages in Red Hat 7 and 8
How to configure hugepages pool using hugeadm in RHEL/CentOS 7
man page of hugeadm

Deepak Prasad

Deepak Prasad

He is the founder of GoLinuxCloud and brings over a decade of expertise in Linux, Python, Go, Laravel, DevOps, Kubernetes, Git, Shell scripting, OpenShift, AWS, Networking, and Security. With extensive experience, he excels in various domains, from development to DevOps, Networking, and Security, ensuring robust and efficient solutions for diverse projects. You can connect with him on his LinkedIn profile.

Can't find what you're searching for? Let us assist you.

Enter your query below, and we'll provide instant results tailored to your needs.

If my articles on GoLinuxCloud has helped you, kindly consider buying me a coffee as a token of appreciation.

Buy GoLinuxCloud a Coffee

For any other feedbacks or questions you can send mail to admin@golinuxcloud.com

Thank You for your support!!

2 thoughts on “3 easy steps to configure hugepages in RHEL/CentOS 7/8”

  1. Any idea how to configure the 1GB pages or select the “Default” size ???

    # hugeadm --pool-list
          Size  Minimum  Current  Maximum  Default
       2097152        0        0     1000        *
    1073741824        0        0        0   
    
    # hugeadm --pool-pages-max 1GB:10GB
    
    # hugeadm --pool-list
          Size  Minimum  Current  Maximum  Default
       2097152        0        0     1000        *
    1073741824        0        0        0   
    Reply
    • For CentOS/RHEL 7

      Edit /etc/default/grub
      Edit the GRUB_CMDLINE_LINUX and append default_hugepagesz=1G

      For CentOS/RHEL 8

      Edit /boot/grub2/grubenv
      Edit kernelopts and append default_hugepagesz=1G

      Rebuild GRUB based on your BIOS

      For BIOS booting grub2-mkconfig -o /boot/grub/grub.cfg
      For EFI booting grub2-mkconfig -o /boot/efi/EFI/redhat/grub.cfg

      Reboot the system to activate the changes

      Reply

Leave a Comment