20200214-Oracle数据库无法启动,Windows自动更新补丁惹的祸!

在这里插入图片描述

环境:

DB:Oracle 11.2.0.1.0
OS:Windows Server 2008

问题:

同事反馈数据库在下午2 点多自动宕机,无法启动,并且最近几天数据库没有做过任何维护变更。

现象:

远程尝试重启Oracle 服务,报错如下:
在这里插入图片描述
先将自动启动实例关闭,尝试手动启动实例。
在这里插入图片描述
执行startup nomount 启动实例,命令一直卡住没有返回结果。
在这里插入图片描述
观察Oracle.exe 占用内存一直上升,达到操作系统内存最大值后,服务器自动重启。
在这里插入图片描述
服务器重启后问题依旧,执行startup nomount 卡住, Oracle.exe 占用内存继续飙升。

查看告警日志没有报错也没有输出。
在这里插入图片描述
猜测是否在启动实例时分配内存出来问题?
尝试多次修改参数文件,将内存不断缩小,但是问题依旧存在。
突然想到既然数据库在问题期间没有任何变更,会不会有可能是操作系统在问题期间做过哪些自动更新导致数据库无法启动呢?
检查操作系统Setup 日志,果然在问题时间点,操作系统自动更新了 KB4012212 补丁。
在这里插入图片描述

解决方案:

由于问题时间点完全吻合,所以猜测数据库无法启动实例、Oracle.exe 异常消耗内存和 KB4012212 更新有关,手动卸载掉 KB4012212 ,再次重启服务器,数据库终于可以正常启动了。建议 Windows 关闭自动更新,比较重要的更新,可以充分测试没问题后再手动更新。
在这里插入图片描述
注意:
这是17 年 5 月处理的一个案例,后来又接手了一个问题现象完全一样的案例,当时也是自信的以为将操作系统上自动更新补丁卸载后就能解决问题,但是在卸载掉补丁重启服务器后发现问题依旧,最终解决办法是在另一台数据库服务器上搭建一个新数据库,然后将生产库上所有的控制文件、数据文件、日志文件拷贝过来,就可以正常启动数据库了,相当于通过数据库物理文件迁移数据库。

欢迎关注我的公众号:IT小Chen

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值