Oracle数据库 功能性很好,应用也很广泛,在进行Oracle数据库的操作时难免会出现一些故障,本文主要为大家介绍Oracle数据库Redo故障的恢复。
一.丢失inactive日志文件组的恢复:
由于inactive日志文件组表示已经完成了检查点(dirty数据已经被写入数据文件)。数据库本身不会发生数据库丢失,如果在这个时候相应的redo丢失/损坏,可以通过clear重建日志文件组恢复。
Alt="oracle数据库" src="https://www.kuidc.com/zdmsl_image/article/20250714193416_64134.jpg" loading="lazy">
通过命令:
oracle 启动必须开启什么进程
2、startup mount dbname安装启动,这种方式启动下可执行:数据库日志归档、数据库介质恢复、使数据文件联机或脱机,重新定位数据文件、重做日志文件。 执行“nomount”,然后打开控制文件,确认数据文件和联机日志文件的位置,但此时不对数据文件和日志文件进行校验检查。 3、startup open dbname先执行“nomount”,然后执行“mount”,再打开包括Redo log文件在内的所有数据库文件,这种方式下可访问数据库中的数据。 4、startup,等于以下三个命令startup nomountalter Database mountalter database open5、startup restrict约束方式启动这种方式能够启动数据库,但只允许具有一定特权的用户访问非特权用户访问时,会出现以下提示:ERROR:ORA-: ORACLE 只允许具有 RESTRICTED SESSION 权限的用户使用6、startup force强制启动方式,当不能关闭数据库时,可以用startup force来完成数据库的关闭,先关闭数据库,再执行正常启动数据库命令7、startup pfile=参数文件名带初始化参数文件的启动方式先读取参数文件,再按参数文件中的设置启动数据库
如何实现physical standby和snapshot standby之间的切换
切换:1.停止Redo Apply如果备库正处于RedoApply过程,需要先取消。 sys@ora11gdg> alter database recover managed standby database cancel;Database altered.2.查看当前备库状态确保备库处于MOUNTED状态sys@ora11gdg> select database_role,open_mode from v$database;DATABASE_ROLEOPEN_MODE---------------- --------------------PHYSICAL STANDBY MOUNTED此时备库是物理备库角色,运行模式是MOUNTED。 3.确保闪回恢复区已指定友情提示:实现SnapshotStandby数据库功能并不需要开启主库和备库的闪回数据库(Flashback Database)功能,与是否开启闪回数据库无关。 sys@ora11gdg> show parameter db_recovery_file_destNAME TYPE VALUE--------------------------- ------------ ------------------------------------db_recovery_file_deststring /u01/app/oracle/flash_recovery_areadb_recovery_file_dest_sizebig integer3852M确认主库闪回功能并未开启sys@ora11g> select FLASHBACK_ON from v$database;FLASHBACK_ON------------------NO确认备库闪回功能并未开启sys@ora11gdg> select FLASHBACK_ON from v$database;FLASHBACK_ON------------------NO4.调整备库到SnapshotStandby数据库状态只需要执行一条非常简单的SQL命令便可以将备库调整到Snapshot Standby数据库。 sys@ora11gdg> alter database convert to snapshot standby;Database @ora11gdg> select database_role,open_mode from v$database;DATABASE_ROLEOPEN_MODE---------------- --------------------SNAPSHOT STANDBY MOUNTED5.将备库置于对外可读写状态sys@ora11gdg> alter database open;Database @ora11gdg> select database_role,open_mode from v$database;DATABASE_ROLEOPEN_MODE---------------- --------------------SNAPSHOT STANDBY READ WRITE一套全新的可读写数据库展现在我们面前。 6.分析切换过程中的日志信息ora11g主库alert日志:Mon Mar 19 18:46:28 2012LNS: Attempting destination LOG_ARCHIVE_DEST_2 Network reconnect (3135)LNS: Destination LOG_ARCHIVE_DEST_2 network reconnect abandonedErrors in file/u01/app/oracle/diag/rdbms/ora11g/ora11g/trace/ora11g_nsa2_:ORA-: connection lost contactError 3135 for archive log file 2 to ora11gdgErrors in file /u01/app/oracle/diag/rdbms/ora11g/ora11g/trace/ora11g_nsa2_:ORA-: connection lost contactLNS: Failed to archive log 2 thread 1 sequence 50 (3135)Errors in file/u01/app/oracle/diag/rdbms/ora11g/ora11g/trace/ora11g_nsa2_:ORA-: connection lost contactora11gdg备库alert日志:Mon Mar 19 18:46:26 2012alter database convert to snapshot standbyStarting background process RVWRMon Mar 19 18:46:26 2012RVWR started with pid=26, OS id=8824Allocated bytes in shared pool for flashback generation bufferCreated guaranteed restore Point SNAPSHOT_STANDBY_REQUIRED_03/19/:46:26krsv_proc_kill: Killing 3 processes (all RFS)Begin: Standby Redo Logfile archivalEnd: Standby Redo Logfile archivalRESETLOGS after complete recovery through change Resetting resetlogs activation ID (0xf8cd26a2)Online log /u01/app/oracle/oradata/ora11gdg/: Thread 1 Group 1 waspreviously clearedOnline log /u01/app/oracle/oradata/ora11gdg/: Thread 1 Group 2 waspreviously clearedOnline log /u01/app/oracle/oradata/ora11gdg/: Thread 1 Group 3 waspreviously clearedStandby became primary SCN: Mon Mar 19 18:46:29 2012Setting recovery target incarnation to 5CONVERT TO SNAPSHOT STANDBY: Complete - Database mounted as snapshot standbyCompleted: alter database convert to snapshot standby关键的一行提示信息“Created guaranteed restore point SNAPSHOT_STANDBY_REQUIRED_03/19/:46:26”,这里给出了我们转换成snapshot的时刻,便于后面的回切。 7.测试备库处于SnapshotStandby数据库对主库日志的接收当主库切换日志时,备库依然可以接收到日志,只是并不应用1)主库切换日志sys@ora11g> alter system switch logfile;System altered.2)主库记录的alert日志内容ora11g主库alert日志:Mon Mar 19 18:52:00 2012Thread 1 cannot allocate new log, sequence 52Private strand flush not completeCurrent log# 3 seq# 51 mem# 0: /u01/app/oracle/oradata/ora11g/ Mar 19 18:52:00 2012ARC3: Standby redo logfile selected for thread 1 sequence 50 for destinationLOG_ARCHIVE_DEST_2Thread 1 advanced to log sequence 52 (LGWR switch)Current log# 1 seq# 52 mem# 0: /u01/app/oracle/oradata/ora11g/ Mar 19 18:52:03 2012Archived Log entry 91 added for thread 1 sequence 51 ID 0xf8cd26a2 dest 1:Mon Mar 19 18:52:03 2012LNS: Standby redo logfile selected for thread 1 sequence 51 for destinationLOG_ARCHIVE_DEST_2LNS: Standby redo logfile selected for thread 1 sequence 52 for destinationLOG_ARCHIVE_DEST_2ora11gdg备库alert日志:Mon Mar 19 18:52:00 2012RFS[5]: Assigned to RFS process 9174RFS[5]: Identified database type as snapshot standby: Client is ARCH pidMon Mar 19 18:52:00 2012RFS[6]: Assigned to RFS process 9176RFS[6]: Identified database type as snapshot standby: Client is ARCH pidRFS[6]: Selected log 4 for thread 1 sequence 50 dbid - branchMon Mar 19 18:52:00 2012Archived Log entry 47 added for thread 1 sequence 50 ID 0xf8cd26a2 dest 1:Mon Mar 19 18:52:03 2012RFS[7]: Assigned to RFS process 9180RFS[7]: Identified database type as snapshot standby: Client is LGWR asyncpid RFS[7]: Selected log 4 for thread 1 sequence 51 dbid - branchMon Mar 19 18:52:04 2012Archived Log entry 48 added for thread 1 sequence 51 ID 0xf8cd26a2 dest 1:RFS[7]: Selected log 4 for thread 1 sequence 52 dbid - branch)查看主库和备库归档目录下的日志文件内容(1)主库归档日志文件ora11g@secdb /home/oracle/arch/ora11g$ ls -ltrtotal 879M……省略其他……-rw-r----- 1 oracle oinstall1.1M Mar 19 18:51 1_50_-rw-r----- 1 oracle oinstall363K Mar 19 18:52 1_51_(2)备库归档日志文件ora11g@secdb /home/oracle/arch/ora11gdg$ ls -ltrtotal 847M……省略其他……-rw-r----- 1 oracle oinstall1.1M Mar 19 18:52 1_50_-rw-r----- 1 oracle oinstall363K Mar 19 18:52 1_51_可见,备库已经接受到主库发过来的日志。 8.在SnapshotStandby数据创建用户和表并初始化数据sys@ora11gdg> create user ocmu identified by ocmu;User @ora11gdg> grant dba to ocmu;Grant @ora11gdg> conn ocmu/@ora11gdg> create table t (x varchar2(8));Table @ora11gdg> insert into t values (Secooler);1 row @ora11gdg> commit;Commit @ora11gdg> select * from t;X--------Secooler
oracle数据库的后台进程有哪些
DBWR进程:该进程执行将缓冲区写入数据文件,是负责缓冲存储区管理的一个ORACLE后台进程。 当缓冲区中的一缓冲区被修改,它被标志为“弄脏”,DBWR的主要任务是将“弄脏”的缓冲区写入磁盘,使缓冲区保持“干净”。 由于缓冲存储区的缓冲区填入数据库或被用户进程弄脏,未用的缓冲区的数目减少。 当未用的缓冲区下降到很少,以致用户进程要从磁盘读入块到内存存储区时无法找到未用的缓冲区时,DBWR将管理缓冲存储区,使用户进程总可得到未用的缓冲区。 ORACLE采用LRU(LEAST RECENTLY USED)算法(最近最少使用算法)保持内存中的数据块是最近使用的,使I/O最小。 在下列情况预示DBWR 要将弄脏的缓冲区写入磁盘:当一个服务器进程将一缓冲区移入“弄脏”表,该弄脏表达到临界长度时,该服务进程将通知DBWR进行写。 该临界长度是为参数DB-BLOCK-WRITE-BATCH的值的一半。 当一个服务器进程在LRU表中查找DB-BLOCK-MAX-SCAN-CNT缓冲区时,没有查到未用的缓冲区,它停止查找并通知DBWR进行写。 出现超时(每次3秒),DBWR 将通知本身。 当出现检查点时,LGWR将通知DBWR.在前两种情况下,DBWR将弄脏表中的块写入磁盘,每次可写的块数由初始化参数DB-BLOCK- WRITE-BATCH所指定。 如果弄脏表中没有该参数指定块数的缓冲区,DBWR从LUR表中查找另外一个弄脏缓冲区。 如果DBWR在三秒内未活动,则出现超时。 在这种情况下DBWR对LRU表查找指定数目的缓冲区,将所找到任何弄脏缓冲区写入磁盘。 每当出现超时,DBWR查找一个新的缓冲区组。 每次由DBWR查找的缓冲区的数目是为寝化参数DB-BLOCK- WRITE-BATCH的值的二倍。 如果数据库空运转,DBWR最终将全部缓冲区存储区写入磁盘。 在出现检查点时,LGWR指定一修改缓冲区表必须写入到磁盘。 DBWR将指定的缓冲区写入磁盘。 在有些平台上,一个实例可有多个DBWR.在这样的实例中,一些块可写入一磁盘,另一些块可写入其它磁盘。 参数DB-WRITERS控制DBWR进程个数。 LGWR进程:该进程将日志缓冲区写入磁盘上的一个日志文件,它是负责管理日志缓冲区的一个ORACLE后台进程。 LGWR进程将自上次写入磁盘以来的全部日志项输出,LGWR输出:当用户进程提交一事务时写入一个提交记录。 每三秒将日志缓冲区输出。 当日志缓冲区的1/3已满时将日志缓冲区输出。 当DBWR将修改缓冲区写入磁盘时则将日志缓冲区输出。 LGWR进程同步地写入到活动的镜象在线日志文件组。 如果组中一个文件被删除或不可用,LGWR 可继续地写入该组的其它文件。 日志缓冲区是一个循环缓冲区。 当LGWR将日志缓冲区的日志项写入日志文件后,服务器进程可将新的日志项写入到该日志缓冲区。 LGWR 通常写得很快,可确保日志缓冲区总有空间可写入新的日志项。 注意:有时候当需要更多的日志缓冲区时,LWGR在一个事务提交前就将日志项写出,而这些日志项仅当在以后事务提交后才永久化。 ORACLE使用快速提交机制,当用户发出COMMIT语句时,一个COMMIT记录立即放入日志缓冲区,但相应的数据缓冲区改变是被延迟,直到在更有效时才将它们写入数据文件。 当一事务提交时,被赋给一个系统修改号(SCN),它同事务日志项一起记录在日志中。 由于SCN记录在日志中,以致在并行服务器选项配置情况下,恢复操作可以同步。 CKPT进程:该进程在检查点出现时,对全部数据文件的标题进行修改,指示该检查点。 在通常的情况下,该任务由LGWR执行。 然而,如果检查点明显地降低系统性能时,可使CKPT进程运行,将原来由LGWR进程执行的检查点的工作分离出来,由 CKPT进程实现。 对于许多应用情况,CKPT进程是不必要的。 只有当数据库有许多数据文件,LGWR在检查点时明显地降低性能才使CKPT运行。 CKPT进程不将块写入磁盘,该工作是由DBWR完成的。 初始化参数CHECKPOINT-PROCESS控制CKPT进程的使能或使不能。 缺省时为FALSE,即为使不能。 SMON进程:该进程实例启动时执行实例恢复,还负责清理不再使用的临时段。 在具有并行服务器选项的环境下,SMON对有故障CPU或实例进行实例恢复。 SMON进程有规律地被呼醒,检查是否需要,或者其它进程发现需要时可以被调用。 PMON进程:该进程在用户进程出现故障时执行进程恢复,负责清理内存储区和释放该进程所使用的资源。 例:它要重置活动事务表的状态,释放封锁,将该故障的进程的ID从活动进程表中移去。 PMON还周期地检查调度进程(DISPATCHER)和服务器进程的状态,如果已死,则重新启动(不包括有意删除的进程)。 PMON有规律地被呼醒,检查是否需要,或者其它进程发现需要时可以被调用。 RECO进程:该进程是在具有分布式选项时所使用的一个进程,自动地解决在分布式事务中的故障。 一个结点RECO后台进程自动地连接到包含有悬而未决的分布式事务的其它数据库中,RECO自动地解决所有的悬而不决的事务。 任何相应于已处理的悬而不决的事务的行将从每一个数据库的悬挂事务表中删去。 当一数据库服务器的RECO后台进程试图建立同一远程服务器的通信,如果远程服务器是不可用或者网络连接不能建立时,RECO自动地在一个时间间隔之后再次连接。 RECO后台进程仅当在允许分布式事务的系统中出现,而且DISTRIBUTED ?C TRANSACTIONS参数是大于进程:该进程将已填满的在线日志文件拷贝到指定的存储设备。 当日志是为ARCHIVELOG使用方式、并可自动地归档时ARCH进程才存在。 LCKn进程:是在具有并行服务器选件环境下使用,可多至10个进程(LCK0,LCK1……,LCK9),用于实例间的封锁。 Dnnn进程(调度进程):该进程允许用户进程共享有限的服务器进程(SERVER PROCESS)。 没有调度进程时,每个用户进程需要一个专用服务进程(DEDICATEDSERVER PROCESS)。 对于多线索服务器(MULTI-THREADED SERVER)可支持多个用户进程。 如果在系统中具有大量用户,多线索服务器可支持大量用户,尤其在客户_服务器环境中。 在一个数据库实例中可建立多个调度进程。 对每种网络协议至少建立一个调度进程。 数据库管理员根据操作系统中每个进程可连接数目的限制决定启动的调度程序的最优数,在实例运行时可增加或删除调度进程。 多线索服务器需要SQL*NET版本2或更后的版本。 在多线索服务器的配置下,一个网络接收器进程等待客户应用连接请求,并将每一个发送到一个调度进程。 如果不能将客户应用连接到一调度进程时,网络接收器进程将启动一个专用服务器进程。 该网络接收器进程不是ORACLE实例的组成部分,它是处理与ORACLE有关的网络进程的组成部分。 在实例启动时,该网络接收器被打开,为用户连接到ORACLE建立一通信路径,然后每一个调度进程把连接请求的调度进程的地址给予于它的接收器。 当一个用户进程作连接请求时,网络接收器进程分析请求并决定该用户是否可使用一调度进程。 如果是,该网络接收器进程返回该调度进程的地址,之后用户进程直接连接到该调度进程。 有些用户进程不能调度进程通信(如果使用SQL*NET以前的版本的用户),网络接收器进程不能将如此用户连接到一调度进程。 在这种情况下,网络接收器建立一个专用服务器进程,建立一种合适的连接.即主要的有:DBWR,LGWR,SMON 其他后台进程有PMON,CKPT等
发表评论