日志移动
数据库状态 open:
步骤1:物理的将文件拷到目的目录
[oracle@localhost orcl]$ cp /opt/oracle/oradata/orcl/redo01.log to /opt/oracle/oradata/redo01.log
步骤2:修改控制文件中相应的记录
SQL>alter database rename file '/opt/oracle/oradata/orcl/redo01.log' to '/opt/oracle/oradata/redo01.log';
修改限制:只有修改的日志组不是current的状态下才能修改(建议最好将需要移动的的日志组切换到inactive的状态下)
查看日志组状态:
SQL> select group#,status from v$log;
如果都是active,或current的话,用这个命令强制写日志文件到磁盘。
SQL> alter system checkpoint;
数据库状态 mount:
修改步骤同上:
没有修改限制,可以修改任意状态的日志组
最后强调移动日志跟数据库是否归档无关
调整日志文件大小,增删组,成员
如果日志过小,导致切换过于频繁的话,会影响数据库性能
1、查看日志组切换时间
SQL> select to_char(first_time,'yyyy-mm-dd hh24:mi:ss'),group# from v$log;
TO_CHAR(FIRST_TIME, GROUP#
------------------- ----------
2013-06-01 18:22:43 1
2013-06-02 09:08:30 2
2013-06-01 18:21:49 3
2、查看日志组大小
SQL> select bytes/(1024*1024) from v$log;
3、查看各个日志组的状态
SQL> select group#,status from v$log;
4、删除日志组(只有在inactive状态下的日志组可以删除,如果要修改的组没有在inactive状态下,那么可以用
这两个命令,调整日志组的状态
SQL> alter system switch logfile;
SQL> alter system checkpoint;
)
SQL> alter database drop logfile group 3;
Database altered.
5、删除日志物理文件
SQL> ho rm /opt/oracle/oradata/orcl/redo03.log;
6、新建日志组 (如果有多个成员,括号内用逗号分隔)
SQL> alter database add logfile group 3 ('/opt/oracle/oradata/orcl/redo03.log') size 100M;
7、添加日志成员(非current状态日志组)
SQL>alter database add logfile member'/opt/oracle/oradata/orcl/redo033.log' to group 3;
8、删除日志成员(非current状态日志组)
SQL>alter database drop logfile member'/opt/oracle/oradata/orcl/redo033.log'
--------------------------------------------------------------
日志文件丢失:
--------------------------------------------------------------
只要日志文件存在就可以启动,假如日志文件丢失了,重建即可。
能有镜像日志文件最好,没有就只能重建了。
重建方法1:用clean语法(可以清空指定日志组)
重建方法2:新建日志文件
重建方法3:resetlogs打开数据库(直接清空所有日志组)
1 :如果数据库是正常关闭
查看当前日志组的状态,如果日志组2(current)丢了,清空时要加unarchived关键字,因为关闭的时候当前日志不会被归档,而且还要确保其他日志组可用,因为清空日志组2的时候,会先切换当前日志组为其他组,如果没有其他日志组可用就会报错,如果下一个日志组也不可用,就先清空其他(已丢失的且非current状态)的日志组,使其可用。最后清空current日志组。
SQL> select group#,status from v$log;
GROUP# STATUS
---------- ----------------
1 INACTIVE
2 CURRENT
3 INACTIVE
SQL> alter database clear logfile '/opt/oracle/oradata/orcl/redo01.log';
SQL> alter database clear logfile '/opt/oracle/oradata/orcl/redo03.log';
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo01.log'; 强制清除没有归档的日志,导致之前的备份全部失效,因为有日志断点
SQL> alter database open;
Database altered
如果只是INACTIVE日志组丢失了,那么只需清空丢失的那个日志组,且不会影响之前的备份文件的恢复(不会照成日志间断,因为正常关机之前都已归档了)
如果只是CURRENT日志组丢失了,也需要清空日志组,但是之前的备份就无效了(因为当前日志没有归档,所以有日志断点)
所以如果清除了当前日志之后一定要重新做全备
2 : 如果数据库非正常关闭
2.1:丢的是inactive日志组
查看丢的日志组对应的状态,如果是inactive则可以用上面清空的方法恢复。如果丢的是active或者current,则不能用清空的方法,因为清空时需要介质恢复,然而你丢的就是介质恢复需要的文件,所以不能恢复
SQL> select group#,status from v$log;
GROUP# STATUS
---------- ----------------
1 UNUSED
2 CURRENT
3 UNUSED
2.2:所有日志全丢了
恢复原理:找回日志文件的方式合上面完全相同。不同的是,开打数据库时需要验证一致性,这个时候加一个隐藏参数就可以了
SQL> select status,group# from v$log;
STATUS GROUP#
---------------- ----------
INACTIVE 1
CURRENT 3
ACTIVE 2
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo02.log';
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo01.log';
ERROR at line 1:
ORA-01624: log 1 needed for crash recovery of instance orcl (thread 1)
ORA-00312: online log 1 thread 1: '/opt/oracle/oradata/orcl/redo01.log'
因为日志组1的状态是active。清空current,active日志组时需要介质恢复。
这个操作具体不知道是什么意思,但是可以使清空时不需要介质恢复 ???????????
SQL> recover database using backup controlfile;
回车
回车
再次清空日志组1,3就不会报错了
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo01.log';
SQL> alter database clear unarchived logfile '/opt/oracle/oradata/orcl/redo03.log';
打开数据库要求resetlogs打开
SQL> alter database open;
ORA-01589: must use RESETLOGS or NORESETLOGS option for database open
resetlogs需要介质恢复
SQL> alter database open resetlogs;
ORA-01113: file 1 needs media recovery
ORA-01110: data file 1: '/opt/oracle/oradata/orcl/system01.dbf'
设置隐藏参数不验证resetlogs
SQL> alter system set "_allow_resetlogs_corruption"=true scope=spfile; ??????????????
System altered.
重启使参数生效
SQL> startup mount force;
ORACLE instance started.
Total System Global Area 209235968 bytes
Fixed Size 1335528 bytes
Variable Size 167776024 bytes
Database Buffers 37748736 bytes
Redo Buffers 2375680 bytes
Database mounted.
成功开启数据库
SQL> alter database open resetlogs;
Database altered.
关闭隐藏参数
SQL> alter system reset "_allow_resetlogs_corruption" scope=spfile;
重启使隐藏参数失效
SQL>shutdown
SQL>startup
SQL> startup mount;
SQL> alter system set "_allow_resetlogs_corruption"=true scope=spfile;
SQL> startup mount force;
SQL> recover database using backup controlfile; 是resetlogs方式打开数据库有效,resetlogs只有在recover database之后才能用
SQL> alter database open resetlogs; 会自动重建所有日志文件
SQL> alter system reset "_allow_resetlogs_corruption" scope=spfile;
SQL>shutdown
SQL>startup