当前位置: 首页 > news >正文

shutdown immediate 持久无法关闭数据库之解决方案

问题引出:测试环境,进行oralce的shutdown immediate,等待时间很长,长的无法等待

ORACLE shutdown 过程:

1、shutdown normal(正常关闭方式):阻止任何用户建立新的连接;等待当前所有正在连接的用户主动断开连接;当所有的用户都断开连接后,将立即关闭数据库

2、shutdown transactional(实务关闭方式):阻止用户连接新的连接和开始新事务;等待所有活动事务提交后,再断开用户连接;当所有的活动实务提交完毕、所有的用户都断开连接后,将关闭数据库

3、shutdown immediate(立即关闭方式):阻止用户连接新连接和开始新事务;将未提交的活动事务回退;关闭数据库

4、shutdown abort(终止关闭方式):阻止用户建立新连接和开始新事务;取消未提交的活动事务,而不是回退;立即终止正在执行的任何SQL语句;立即关闭数据库

无疑,shutdown abort是最开速关闭数据库的方式,但是很可能会使数据库处于不一致状态,严重可能损坏数据库,导致数据库起不来,特别是生产环境。虽然现在是测试环境,但是也不建议这样做。推荐使用shutdown immediate方式关闭数据库。

快速关闭数据库的因素:

1、连接的客户端进程数量

2、未提交的事务占用的UNDO BLOCK数量

3、长时间运行的会话

4、SMON进程清理临时段的速度

2、查看预警日志文件(alert_sid.log)的位置

SQL> show parameter dump
NAME TYPE VALUE


background_core_dump string partial
background_dump_dest string /u01/oracle/admin/bdump
core_dump_dest string /u01/oracle/admin/cdump
max_dump_file_size string 10240
shadow_core_dump string partial
user_dump_dest string /u01/oracle/admin/udump

查看alert日志如下: /u01/oracle/admin/bdump/alert_biusdb.log 以下信息是样例

Shutting down instance (immediate)
Sat Aug 24 15:25:40 2013
Shutting down instance: further logons disabled
License high water mark = 683
Sat Aug 24 15:30:39 2013
Active call for process 26760 user ‘orarep’ program’oracle@pmsdb2’
Active call for process 20349 user ‘orarep’ program’oracle@pmsdb2’
Active call for process 1813 user ‘orarep’ program’oracle@pmsdb2’
Active call for process 10694 user ‘orarep’ program’oracle@pmsdb2’
Active call for process 26394 user ‘orarep’ program’oracle@pmsdb2’
System State dumped to trace file /oraprep/oracle/admin/repdb/udump/repdb_ora_16122.trc
Sat Aug 24 15:31:02 2013
SHUTDOWN: waiting for active calls to complete.
Sat Aug 24 15:31:02 2013
Instance shutdown cancelled
Sat Aug 24 15:35:56 EAT 2013
Shutting down instance (immediate)
Sat Aug 24 15:35:56 EAT 2013
Shutting down instance: further logons disabled
License high water mark = 683

随机,手动kill掉这些数据库连接进程:

eg:

orarep@pmsdb2[/oraprep/oracle/admin/repdb/bdump] k i l l − 910694 o r a r e p @ p m s d b 2 [ / o r a p r e p / o r a c l e / a d m i n / r e p d b / b d u m p ] kill -9 10694 orarep@pmsdb2[/oraprep/oracle/admin/repdb/bdump] kill910694orarep@pmsdb2[/oraprep/oracle/admin/repdb/bdump]kill -9 23362
orarep@pmsdb2[/oraprep/oracle/admin/repdb/bdump]$kill -9 9944

另外如果进程之多可以使用:

ps aux |grep "LOCAL=NO" |awk '{printf "%s ", $2}' |xargs kill -9

ps -ef|grep $ORACLE_SID|grep -v ora_|grep LOCAL=NO|awk '{print $2}'|xargs kill

命令

随机再次关闭数据库:

SQL> shutdown immediate

Database closed.

Database dismounted.

总结:

这是由于进程lock资源导致 的问题,因此需要先释放资源,完成数据库的关闭。

http://www.xdnf.cn/news/842077.html

相关文章:

  • 最全地理数据下载网址
  • shell IFS
  • LTDC/DMA2D—液晶显示***
  • Java核心技术2
  • 费马定理中值定理_达布中值定理
  • Prime95怎么使用?Prime95烤机教程
  • 起点导航系统源码最新V2.6开源可运营版
  • Perhaps, perhaps, perhaps 英国电视剧冤家对对碰主题曲
  • 企业终端安全管理软件有哪些?终端安全管理软件哪个好?
  • 编码器类型原理知识汇总(增量式/绝对式/绝对值)
  • Material Design之CollapsingToolbarLayout 相关属性和方法介绍
  • 【测试面试题】14题常见APP测试面试题(参考答案)
  • Rational Rose 2007 下载,安装及破解激活图文教程
  • USB复合设备(mass storagehid)
  • 51单片机程序烧录教程
  • 域名注册和域名备案
  • Python 将PowerPoint (PPT/PPTX) 转为HTML
  • Installshield 打包安装包心得
  • Java面试八股--07-项目篇
  • 服务器被攻击了怎么处理
  • 自组织网络(Ad hoc)
  • 丛林小英雄迪亚哥 Go Diego Go 14张DVD,朵拉的表兄弟
  • 《恋爱的犀牛》情节和语录
  • 李开复:看好视频网站在中国未来的发展
  • 从零开始学大数据框架Hudi,这些学习网站,助你一臂之力!
  • 8个免费在线编程游戏网站,让每个人都可以学习编程
  • Dreamweaver CS6破解教程[序列号+破解补丁]
  • 音视频编解码技术(一):MPEG-4/H.264 AVC 编解码标准
  • 程序设计基础(c语言)(第3版)课后习题答案
  • [经验]Mpx200上网记