aio-max-nr达到上限导致数据库性能问题

问题说明:

rac数据库节点一表面上看由于归档等待事件导致业务性能问题。

问题分析过程:

查看awr报告top事件,等待事件主要为归档切换问题:

查看事件,归档等待达到20多分钟

检查节点alert日志发现,最早12点53分49秒就有归档失败报错,如下:

到13:19:39的时候,发生了所有online logs需要归档,导致数据库等待归档事件,如下:

查看最早发生归档异常时间段的trace日志,如下图:

在告警中,报asynch I/O内核限制,主要是由于异步IO请求达到AIO-MAX-NR的上限。

查看当前内核参数配置,cat /etc/sysctl.conf,如下图:

结论及解决:

结论分析

异步IO请求达到AIO-MAX-NR的上限,导致后续文件句柄不能生成,不能打开新的文件,所以导致归档不能打开写入到本地。

解决方案

  1. 优化内核参数,建议调整如下参数:

调整fs.aio-max-nr为当前1.5倍,并同时调整file-max、fs.aio-nr为当前1.5倍,fs.aio-nr没有设置,可以通过"sysctl -a|grep aio"命令查看当前的fs.aio-nr配置,具体设置值参考如下:

fs.aio-max-nr = 4718592

fs.file-max = 10223616

使用"sysctl -p"使参数生效。

aio-max-nr :允许的并发请求的最大个数,一是来自网络的I/O;二是对文件(设备)的I/O。

对于服务器程序,I/O是制约系统性能最关键的因素。对于需要处理大量连接的高并发服务器程序,异步I/O几乎是不二的选择。

相关推荐
time never ceases15 分钟前
使用docker方式进行Oracle数据库的物理迁移(helowin/oracle_11g)
数据库·docker·oracle
Frank牛蛙18 分钟前
1.每日SQL----2024/11/7
数据库·sql
Ciderw20 分钟前
块存储、文件存储和对象存储详细介绍
网络·数据库·nvme·对象存储·存储·块存储·文件存储
薛晓刚21 分钟前
数据库优化指南:如何将基本功能运用到极致?
数据库
stars_User24 分钟前
MySQL数据库面试题(下)
数据库·mysql
未来之窗软件服务1 小时前
sql速度优化多条合并为一条语句
数据库
山东布谷科技官方1 小时前
布谷直播源码部署服务器关于数据库配置的详细说明
运维·服务器·数据库·直播系统源码·直播源码·直播系统搭建·直播软件开发
易云码1 小时前
信息安全建设方案,网络安全等保测评方案,等保技术解决方案,等保总体实施方案(Word原件)
数据库·物联网·安全·web安全·低代码
newxtc1 小时前
【客观理性深入讨论国产中间件及数据库-科创基础软件】
数据库·中间件·国产数据库·国产中间件·科创
水月梦镜花1 小时前
redis:list列表命令和内部编码
数据库·redis·list