Oracle 标准大页和透明大页
2021/9/4 19:07:35
本文主要是介绍Oracle 标准大页和透明大页,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
说明:
标准大页(HugePages)
标准大页(HugePages)是从 Linux Kernel 2.6 后被引入的。
目的是用更大的内存页面(memory page size)以适应越来越大的系统内存,让操作系统可以支持现代硬件架构的大页面容量功能。
透明大页(Transparent HugePages)
透明大页(Transparent Huge Pages)缩写为THP,透明超大页面(THP)在RHEL 6中默认情况下对所有应用程序都是启用的。
内核试图尽可能分配巨大的页面,主内核地址空间本身被映射为巨大的页面,减少了内核代码的TLB压力。
内核将始终尝试使用大页来满足内存分配。
如果没有可用的巨大页面(例如由于物理连续内存不可用),内核将回退到正常的4KB页面。
THP也是可交换的(不像hugetlbfs)。
这是通过将大页面分成更小的4KB页面来实现的,然后这些页面被正常地换出。
透明大页存在的问题:
Oracle Linux team在测试的过程中发现,如果linux开启透明大页THP,则I/O读写性能降低30%;
如果关闭透明大页THP,I/O读写性能则恢复正常。
另,建议在Oracle Database中不要使用THP。
ORACLE官方不建议在使用RedHat 6, OEL 6, SLES 11 and UEK2 kernels 时开启透明大页(THP),因为透明大页存在一些问题:
1. 在RAC环境下,透明大页(THP)会导致异常节点重启和性能问题;
2. 在单机环境中,透明大页(THP)也会导致一些异常的性能问题;
标准大页和透明大页区别:
两者区别在于大页的分配机制,标准大页管理是预分配 方式,而透明大页管理则是动态分配 方式。
目前透明大页与传统大页混合使用会出现一些问题,导致性能问题和系统重启。
如何开启标准大页(HugePages)
适用于:
1.Kernel Version 2.6及更高。
2.Oracle AMM内存管理和HugePages不兼容,确保在AMM关闭的情况下启动HugePages。
启用HugePages方法:
1 运行以下命令以确定内核是否支持HugePages
$ grep Huge /proc/meminfo
2 配置memlock
在/etc/security/limits.conf文件中设置memlock值,memlock设置以KB为单位。
当启用HugePages内存时,最大锁定内存限制应至少设置为当前服务器内存的90%。
禁用HugePages内存时,最大锁定内存限制应设置为至少3145728 KB(3 GB)。
例如,如果安装了64 GB RAM,则添加以下条目以增加最大锁定内存地址空间:
* soft memlock 60397977
* hard memlock 60397977
也可以将memlock值设置为高于SGA要求的值。
再次以oracle用户身份登录并运行ulimit-l命令以验证新的memlock设置:
su - oracle
$ ulimit -l
3 启动实例
检查实例是启动状态
srvctl status instance -d dbname
如果没启动,手动启动实例
srvctl start instance -d dbname -i instance_name -o open
4 使用脚本为当前共享内存段计算hugepages配置的建议值:
root用户下执行
chmod +x hugepages_settings.sh
./hugepages_settings.sh
脚本来自My Oracle Support note 401749.1,脚本详细内容见末尾。
5 停止数据库实例
srvctl stop instance -d dbname -i instance_name -o immediate
6 设置vm.nr_hugepages内核参数
写入配置文件,永久生效
vi /etc/sysctl.conf
vm.nr_hugepages=<value from above>
sysctl -p
# sysctl -w vm.nr_hugepages=<value from above> 临时改变,重启失效
7 启动实例
srvctl start instance -d dbname -i instance_name -o open
8 检查可用的hugepages
$ grep Huge /proc/meminfo
如果配置没生效,需要重启服务器
[root@rac1 ~]# grep Huge /proc/meminfo
AnonHugePages: 0 kB
HugePages_Total: 179
HugePages_Free: 9
HugePages_Rsvd: 7
HugePages_Surp: 0
Hugepagesize: 2048 kB
参考:
1 2 3 |
My Oracle Support note 401749.1
My Oracle Support note 361323.1
Database Administrator's Reference for Linux and UNIX System-Based Operating Systems
|
如何关闭透明大页(Transparent HugePages)
Linux7 默认情况下 是开启透明大页功能的。检查系统对应版本
[root@DB ~]# cat /etc/redhat-release
Red Hat Enterprise Linux Server release 7.2 (Maipo)
关闭THP
[root@DB ~]# cat /sys/kernel/mm/transparent_hugepage/enabled
[always] madvise never
默认情况下,状态为 always,需要调整为 never
THP 禁用方的几种方法
方法 1:
[root@DB ~]# vi /etc/default/grub
GRUB_CMDLINE_LINUX="rd.lvm.lv=rhel/swap rd.lvm.lv=rhel/root rhgb quiet transparent_hugepage=never"
运行下列命令使之修改生效:
[root@DB ~]# grub2-mkconfig -o /boot/grub2/grub.cfg
方法 2:
1 2 3 4 5 |
[root@DB ~] #vi /etc/rc.local
if test -f /sys/kernel/mm/transparent_hugepage/enabled ; then echo never > /sys/kernel/mm/transparent_hugepage/enabled
fi
if test -f /sys/kernel/mm/transparent_hugepage/defrag ; then echo never > /sys/kernel/mm/transparent_hugepage/defrag
fi
|
[root@DB ~]# cat /sys/kernel/mm/transparent_hugepage/enabled
always madvise [never]
方法 3:
[root@DB ~]# echo never > /sys/kernel/mm/transparent_hugepage/enabled
[root@DB ~]# cat /sys/kernel/mm/redhat_transparent_hugepage/enabled
always madvise [never]
查看是否关闭透明大页
[root@DB ~]# cat /sys/kernel/mm/redhat_transparent_hugepage/enabled
always madvise [never]
如果输出结果为[always]表示透明大页启用了。[never]表示透明大页禁用;
[root@DB ~]# grep -i HugePages_Total /proc/meminfo
如果 HugePages_Total,返回 0,也意味着透明大页禁用了
[root@DB ~]# cat /proc/sys/vm/nr_hugepages
返回 0 也意味着透明大页禁用了。
hugepages_settings.sh 脚本内容如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
#!/bin/bash
#
# 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 the overall 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.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" ;;
'4.14' ) echo "Recommended setting: vm.nr_hugepages = $NUM_PG" ;;
'5.4' ) echo "Recommended setting: vm.nr_hugepages = $NUM_PG" ;;
*) echo "Kernel version $KERN is not supported by this script (yet). Exiting." ;;
esac
# End
|
这篇关于Oracle 标准大页和透明大页的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用