linux配置大頁HugePages
IF
SGA >= 2GB AND sessions >= 500
THEN
enabling HugePages becomes a requirement on Linux 64-bit system.
二、怎麼配置How to Configure HugePages
The configuration steps below will guide you to do a
persistent system configuration where you would need to do a complete
reboot of the system. Please plan your operations accordingly:
Step 1: Have the memlock user limit set in /etc/security/limits.conf file. Set the value (in KB) slightly smaller than installed RAM. e.g. If you have 64GB RAM installed, you may set:
* soft memlock * hard memlock 60397977
There is no harm in setting this value larger than your SGA requirements.
The parameters will be set by default on:
- Oracle Linux with oracle-validated package (See Document 437743.1) installed.
- Oracle Exadata DB compute nodes
Step 2: Re-logon to the Oracle product owner account (e.g. 'oracle') and check the memlock limit
$ ulimit -l
Step 3: If you have Oracle Database 11g or later, the default database created uses the Automatic Memory Management (AMM) feature which is incompatible with HugePages. Disable AMM before proceeding. To disable, set the initialization parameters MEMORY_TARGET and MEMORY_MAX_TARGET to 0 (zero). Please see Document 749851.1 for further information in case you encounter the error below:
Step 4: Make sure that all your database instances are up (including ASM instances) as they would run on production. Use the script hugepages_settings.sh in Document 401749.1 to calculate the recommended value for the vm.nr_hugepageskernel parameter. e.g.:
$
Note: You can also calculate a proper value for the parameter
yourself but that is not advised if you do not have extensive experience
with HugePages and concepts.
Step 5: Edit the file /etc/sysctl.conf and set the vm.nr_hugepages parameter there:
...
...
This will make the parameter to be set properly with each reboot.
Step 6: Stop all the database instances and reboot the server
(Although
settings could have been done dynamically they would not be effective
to the extent we require before a reboot. The best practice is to do a
persistent system configuration and perform a reboot to complete the
configuration as presented through the steps above)
What If the Database / SGA Configurations Change?
The performed configuration is basically based on the RAM installed and combined size of SGA of database instances you are running. Based on that when:
- Amount of RAM installed for the Linux OS changed
- New database instance(s) introduced
- SGA size / configuration changed for one or more database instances
- Poor database performance
- System running out of memory or excessive swapping
- Database instances cannot be started
- Crucial system services failing
三、檢查確認Check and Validate the Configuration
After the system is rebooted, make sure that your database instances (including the ASM instances) are started. Automatic startup via OS configuration or CRS, or manual startup (whichever method you use) should have been performed. Check the HugePages state from /proc/meminfo. e.g.:
HugePages_Total: 1496
HugePages_Free: 485
HugePages_Rsvd: 446
HugePages_Surp: 0
The values in the output will vary. To make sure that the configuration is valid, the HugePages_Free value should be smaller than HugePages_Total and there should be some HugePages_Rsvd. HugePages_Rsvd counts free pages that are reserved for use (requested for an SGA, but not touched/mapped yet).
The sum of Hugepages_Free and HugePages_Rsvd may be smaller than your total combined SGA as instances allocate pages dynamically and proactively as needed.
四、計算大頁Shell Script to Calculate Values Recommended Linux HugePages / HugeTLB Configuration
1.[root@wang ~]# vi hugepages_settings.sh
--新增如下指令碼
#
# hugepages_settings.sh
#
# Linux bash script to compute values for the
# recommended HugePages/HugeTLB configuration
# on Oracle Linux
#
# Note: This script does calculation for all shared memory
# segments available when the script is run, no matter it
# is an Oracle RDBMS shared memory segment or not.
#
# This script is provided by Doc ID 401749.1 from My Oracle Support
#
# Welcome text
echo "
This script is provided by Doc ID 401749.1 from My Oracle Support
() where it is intended to compute values for
the recommended HugePages/HugeTLB configuration for the current shared
memory segments on Oracle Linux. Before proceeding with the execution please note following:
* For ASM instance, it needs to configure ASMM instead of AMM.
* The 'pga_aggregate_target' is outside the SGA and
you should accommodate this while calculating SGA size.
* In case you changes the DB SGA size,
as the new SGA will not fit in the previous HugePages configuration,
it had better disable the whole HugePages,
start the DB with new SGA size and run the script again.
And make sure that:
* Oracle Database instance(s) are up and running
* Oracle Database 11g Automatic Memory Management (AMM) is not setup
(See Doc ID 749851.1)
* The shared memory segments can be listed by command:
# ipcs -m
Press Enter to proceed..."
read
# Check for the kernel version
KERN=`uname -r | awk -F. '{ printf("%d.%d\n",$1,$2); }'`
# Find out the HugePage size
HPG_SZ=`grep Hugepagesize /proc/meminfo | awk '{print $2}'`
if [ -z "$HPG_SZ" ];then
echo "The hugepages may not be supported in the system where the script is being executed."
exit 1
fi
# Initialize the counter
NUM_PG=0
# Cumulative number of pages required to handle the running shared memory segments
for SEG_BYTES in `ipcs -m | cut -c44-300 | awk '{print $1}' | grep "[0-9][0-9]*"`
do
MIN_PG=`echo "$SEG_BYTES/($HPG_SZ*1024)" | bc -q`
if [ $MIN_PG -gt 0 ]; then
NUM_PG=`echo "$NUM_PG+$MIN_PG+1" | bc -q`
fi
done
RES_BYTES=`echo "$NUM_PG * $HPG_SZ * 1024" | bc -q`
# An SGA less than 100MB does not make sense
# Bail out if that is the case
if [ $RES_BYTES -lt 100000000 ]; then
echo "***********"
echo "** ERROR **"
echo "***********"
echo "Sorry! There are not enough total of shared memory segments allocated for
HugePages configuration. HugePages can only be used for shared memory segments
that you can list by command:
# ipcs -m
of a size that can match an Oracle Database SGA. Please make sure that:
* Oracle Database instance is up and running
* Oracle Database 11g Automatic Memory Management (AMM) is not configured"
exit 1
fi
# Finish with results
case $KERN in
'2.2') echo "Kernel version $KERN is not supported. Exiting." ;;
'2.4') HUGETLB_POOL=`echo "$NUM_PG*$HPG_SZ/1024" | bc -q`;
echo "Recommended setting: vm.hugetlb_pool = $HUGETLB_POOL" ;;
'2.6') echo "Recommended setting: vm.nr_hugepages = $NUM_PG" ;;
'3.8') echo "Recommended setting: vm.nr_hugepages = $NUM_PG" ;;
'3.10') echo "Recommended setting: vm.nr_hugepages = $NUM_PG" ;;
'4.1') echo "Recommended setting: vm.nr_hugepages = $NUM_PG" ;;
esac
# End
"hugepages_settings.sh" [New] 94L, 3254C written
[root@wang ~]#
2.[root@wang ~]# chmod +x hugepages_settings.sh
3.[root@wang ~]# ./hugepages_settings.sh
.........................
省略..............
Press Enter to proceed...
Recommended setting: vm.nr_hugepages = 102404
執行後會有輸出建議值。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31397003/viewspace-2148020/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux 下配置 HugePagesLinux
- 配置 HugePages for Oracle on Linux (x86-64)OracleLinux
- HugePages on LinuxLinux
- Linux HugepagesLinux
- linux大記憶體Hugepages最佳化Linux記憶體
- Linux Hugepages[轉]Linux
- 【TUNE_ORACLE】Oracle資料庫與HugePages(二)HugePages配置和限制Oracle資料庫
- Linux Hugepages的使用(引用)Linux
- Oracle 之 配置HugePages記憶體Oracle記憶體
- mysql大頁配置MySql
- Oracle Linux 7禁用Transparent HugePagesOracleLinux
- hugepages_setting(linux大記憶體設定指令碼)Linux記憶體指令碼
- LINUX HUGEPAGES在大記憶體資料庫中的應用Linux記憶體資料庫
- Shell Script to Calculate Values Recommended Linux HugePagesLinux
- Linux HugePages /proc/meminfo輸出行的含義Linux
- linux上Oracle的sga(HugePages)分配問題LinuxOracle
- ID 361468.1 HugePages on Oracle Linux 64-bitOracleLinux
- 【大頁記憶體】Oracle資料庫配置大頁記憶體記憶體Oracle資料庫
- 0927hugepages與nr_overcommit_hugepagesMIT
- oracle 大頁配置詳細介紹Oracle
- AIX上為ORACLE配置大頁面AIOracle
- HugePages詳解
- HugePages on Oracle Linux 64-bit (Doc ID 361468.1)OracleLinux
- 【TUNE_ORACLE】Oracle資料庫與HugePages(四)如何禁用透明大頁Oracle資料庫
- How to disable transparent hugepages (THP) on Red Hat Enterprise Linux 7Linux
- Linux 11G RAC啟用HugePages與AMM的禁用Linux
- Linux中設定hugepages 在記憶體中 lock SGALinux記憶體
- 【TUNE_ORACLE】Oracle資料庫與HugePages(一)HugePages概念和優勢Oracle資料庫
- 【Linux】配置一個強大的Vim!!Linux
- Linux標準大頁設定不合理案例Linux
- 【TUNE_ORACLE】Oracle資料庫與HugePages(三)HugePages常見問題和解決辦法Oracle資料庫
- t620折騰 —— 給虛擬機器配置大頁虛擬機
- oracle大頁Oracle
- LINUX下為ORACLE資料庫設定大頁--hugepageLinuxOracle資料庫
- Linux 中的“大記憶體頁”(hugepage)是個什麼?Linux記憶體
- linux配置Linux
- myBatis分頁外掛配置MyBatis
- MySQL InnoDB頁面大小配置MySql