Oracle单库环境下计划内启停数据库的步骤

一、正常(计划内)停数据库操作流程

前提:登录数据库服务器操作系统

1、停止数据库监听程序

复制代码
su - oracle
lsnrctl stop

2、通知业务维护人员,停止数据库上的所有业务程序(包括所有前台和后台程序)。

3、检查数据库上是否存在大批量更新数据的运行事务(通过运行事务所使用的undo回滚段大小来判断,一般undo回滚段使用超过500M表示存在大的运行事务),如果存在,等待事务正常结束提交后,再停止数据库。

复制代码
具体检查方法如下:(查询出来的第二列为事务undo回滚段大小,单位为M)
SELECT  nvl(s.username,'None') oracle_user,
 trunc(t.used_ublk*TO_NUMBER(x.value)/1024/1024,2) as undo_mb,t.START_TIME
 FROM v$rollname   r,v$session s,v$transaction t,v$parameter x 
 WHERE  s.taddr = t.addr AND  r.usn = t.xidusn(+) AND x.name = 'db_block_size' 
 ORDER by undo_mb desc;
备注:如果数据库中存在大批量事务(例如上述查询出来的UNDO大于1024M),必须等待事务完成,或者杀掉事务进程后,必须等待事务回滚操作完成;

如果数据库中存在大事务,直接正常immediate方式关闭数据库,可能会非常耗时,且很大概率无法关闭。
而abort强制方式关闭数据库,则有概率引起回滚段异常,导致无法正常启动,作为数据库维护人员,一定要注意。

4、登录数据库服务器操作系统,杀掉所有通过网络连接数据库的进程(外部连接)

复制代码
su  -  oracle
ps -ef|grep oracle|grep LOCAL=NO|grep -v grep|awk '{print $2}'|xargs kill -9
ps -ef|grep oracle|grep LOCAL=NO|grep -v grep|awk '{print $2}'|xargs kill -9
执行两次,确保外部连接杀干净

检查:
ps -ef|grep oracle|grep LOCAL=NO|grep -v grep

5、手工执行数据库检查点,一般执行三次。

备注:数据库检查点会将已经提交的事务(事务SQL语句中更新的数据块),全部从内存刷新到磁盘数据文件,保证数据一致性,意义有三点:
1)缩短正常停库时间
2)极大提高正常immediate关库的成功性
3)出现极小概率必须使用abort强制关闭时,可以大概率规避abort强制关库引起的数据块损坏、数据库无法正常起来等很多问题

复制代码
具体执行方法如下:
su - oracle
sqlplus    "/as sysdba"
alter  system  checkpoint;
alter  system  checkpoint;
alter  system  checkpoint;
exit

6、正常关闭数据库

复制代码
su - oracle
sqlplus    "/as sysdba"
shutdown  immediate;

二、正常(计划内)启数据库操作流程

前提:登录数据库服务器操作系统

复制代码
1、启动数据库监听程序。
su - oracle
lsnrctl start
2、正常启动数据库。
su - oracle
sqlplus "/as sysdba"
startup
exit
3、启动数据库上的所有业务程序,包括前台和后台程序。
4、简单的业务功能可用性测试
相关推荐
数据库小学妹12 小时前
数据库连接池避坑指南:告别“连接超时”与“资源耗尽”,让系统跑得更快!
数据库·redis·sql·mysql·缓存·dba
dishugj12 小时前
HANA 数据库备份与恢复
数据库·oracle
前进的李工13 小时前
EXPLAIN输出格式全解析:JSON、TREE与可视化
开发语言·数据库·mysql·性能优化·explain
达梦产品与服务13 小时前
稳扎稳打,持续迭代 | SQLark V3.10 更新,30+ 项优化与修复
mysql·oracle·达梦数据库·pg·sqlark百灵连接
難釋懷13 小时前
Redis网络模型-IO多路复用模型-poll模式
网络·数据库·redis
dFObBIMmai13 小时前
如何在 CSS 中实现元素的绝对定位,使其不受窗口尺寸变化影响
jvm·数据库·python
treesforest14 小时前
IP精准定位服务:从城市轮廓到街道坐标,技术如何重塑空间感知
网络·数据库·网络协议·tcp/ip·ip
大明者省14 小时前
宝塔开了端口,Ubuntu 还得开相应端口才能打通
服务器·数据库·ubuntu
Teable任意门互动14 小时前
AI原生开源多维表格有哪些?主流开源多维表格对比解析
数据库·开源·excel·钉钉·飞书·开源软件·ai-native
TDengine (老段)15 小时前
MNode 内部机制深度解析 — SDB、事务引擎与 DDL 处理全链路
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据