如何启动或关闭Oracle的归档模式

如何启动或关闭Oracle的归档模式,第1张

如何启动或关闭Oracle的归档模式

Sql代码

sql> archive log list; #查看是不是归档方式

sql> alter system set log_archive_start=true scope=spfile; #启用主动归档

sql> alter system set log_archive_dest=''location=/oracle/ora9/oradata/arch'' scope=spfile;#设置归档路径

sql> alter system set log_archive_dest_1=''location=/oracle/ora9/oradata/arch1'' scope=spfile;

sql> alter system set log_archive_dest_2=''location=/oracle/ora9/oradata/arch2'' scope=spfile;

#如果归档到两个位置,则可以通过上边方法实现

sql> alter system set log_archive_format=''arch_%d_%t_%r_%slog'' #设置归档日记款式

sql> shutdown immediate;

sql> startup mount; #打开控制文件,不打开数据文件

sql> alter database archivelog; #将数据库切换为归档模式

sql> alter database open; #将数据文件打开

sql> archive log list; #查看此时是否处于归档模式

查询以确定数据库位于archivelog模式中且归档过程正在运行

sql> select log_mode from v$database;

sql> select archiver from v$instance;

Sql代码

日志切换

sql> alter system switch logfile;

这次日志切换将归档写到两个目标地,

即上边的/oracle/ora9/oradata/arch1和/oracle/ora9/oradata/arch1,

要是要对目录确认

在oracle情况中运行如下查询:

sql> select name from v$archived_log;

而后在 *** 作系统中确认查询所列出的文件

二 设置非归档方式

Sql代码

sql> archive log list; #查看是否是归档方式

sql> alter system set log_archive_start=false scope=spfile;

#禁用自动归档

sql> shutdown immediate;

sql> startup mount; #打开控制文件,不打开数据文件

sql> alter database noarchivelog; #将数据库切换为非归档模式

sql> alter database open; #将数据文件打开

sql> archive log list; #查看此时便处于非归档模式

三 归档相关命令

Sql代码

archive log stop;

archive log start;

archive log list;

show parameters;

show parameters log_archive_start;

show parameters log_archive_max_process; #归档进程数

alter system set log_archive_max_process=5; #将归档进程数改为5

select from v$bgprocess; #检察后台进程

一。查看oracle数据库是否为归档模式:

Sql代码

1select name,log_mode from v$database;

NAME LOG_MODE

------------------ ------------------------

QUERY NOARCHIVELOG

2使用ARCHIVE LOG LIST 命令

Database log mode No Archive Mode

Automatic archival Disabled

Archive destination /data/oracle/product/1020/db_1//dbs/arch

Oldest online log sequence 739

Current log sequence 741

[sql] view plaincopyprint

1select name,log_mode from v$database;

NAME LOG_MODE

------------------ ------------------------

QUERY NOARCHIVELOG

2使用ARCHIVE LOG LIST 命令

Database log mode No Archive Mode

Automatic archival Disabled

Archive destination /data/oracle/product/1020/db_1//dbs/arch

Oldest online log sequence 739

Current log sequence 741

1select name,log_mode from v$database;

NAME LOG_MODE

------------------ ------------------------

QUERY NOARCHIVELOG

2使用ARCHIVE LOG LIST 命令

Database log mode No Archive Mode

Automatic archival Disabled

Archive destination /data/oracle/product/1020/db_1//dbs/arch

Oldest online log sequence 739

Current log sequence 741

二。什么是Oracle归档模式?

Oracle数据库有联机重做日志,这个日志是记录对数据库所做的修改,比如插入,删除,更新数据等,对这些 *** 作都会记录在联机重做日志里。一般数据库至少要有2个联机重做日志组。当一个联机重做日志组被写满的时候,就会发生日志切换,这时联机重做日志组2成为当前使用的日志,当联机重做日志组2写满的时候,又会发生日志切换,去写联机重做日志组1,就这样反复进行。

如果数据库处于非归档模式,联机日志在切换时就会丢弃 而在归档模式下,当发生日志切换的时候,被切换的日志会进行归档。比如,当前在使用联机重做日志1,当1写满的时候,发生日志切换,开始写联机重做日志2,这时联机重做日志1的内容会被拷贝到另外一个指定的目录下。这个目录叫做归档目录,拷贝的文件叫归档重做日志。

数据库使用归档方式运行时才可以进行灾难性恢复。

1归档日志模式和非归档日志模式的区别

非归档模式只能做冷备份,并且恢复时只能做完全备份最近一次完全备份到系统出错期间的数据不能恢复

归档模式可以做热备份,并且可以做增量备份,可以做部分恢复

用ARCHIVE LOG LIST 可以查看期模式状态时归档模式还是非归档模式

===============================================================

三。配置数据库的归档模式

改变非归档模式到归档模式:

Sql代码

1)SQL>SHUTDOWN NORMAL/IMMEDIATE; 先down下数据

2)SQL>START MOUNT; 启动数据库实例到mount状态,但不要打开

3)SQL>ALTER DATABASE ARCHIVELOG; 设置数据库为归档日志模式

4)SQL>ALTER DATABASE OPEN; 打开数据库

5)SQL>archive log list; 确认数据库现在处于归档日志模式

6)SQL>archive log all; 将这个时间点的redo logs归档

[sql] view plaincopyprint

1)SQL>SHUTDOWN NORMAL/IMMEDIATE; 先down下数据

2)SQL>START MOUNT; 启动数据库实例到mount状态,但不要打开

3)SQL>ALTER DATABASE ARCHIVELOG; 设置数据库为归档日志模式

4)SQL>ALTER DATABASE OPEN; 打开数据库

5)SQL>archive log list; 确认数据库现在处于归档日志模式

6)SQL>archive log all; 将这个时间点的redo logs归档

1)SQL>SHUTDOWN NORMAL/IMMEDIATE; 先down下数据

2)SQL>START MOUNT; 启动数据库实例到mount状态,但不要打开

3)SQL>ALTER DATABASE ARCHIVELOG; 设置数据库为归档日志模式

4)SQL>ALTER DATABASE OPEN; 打开数据库

5)SQL>archive log list; 确认数据库现在处于归档日志模式

6)SQL>archive log all; 将这个时间点的redo logs归档

5)SQL>做一次完全备份,因为非归档日志模式下产生的备份日志对于归档模式已经不可用了这一步非非常重要!

Sql代码

SQL>alter tablespace users begin bacup;

[sql] view plaincopyprint

SQL>alter tablespace users begin bacup;

SQL>alter tablespace users begin bacup;

====================

如果停止归档模式就用

alter database noarchivelog

========================

改变归档模式到非归档模式:

Sql代码

1)SQL>SHUTDOWN NORMAL/IMMEDIATE;

2)SQL>START MOUNT;

3)SQL>ALTER DATABASE NOARCHIVELOG;

4)SQL>ALTER DATABASE OPEN;

[sql] view plaincopyprint

1)SQL>SHUTDOWN NORMAL/IMMEDIATE;

2)SQL>START MOUNT;

3)SQL>ALTER DATABASE NOARCHIVELOG;

4)SQL>ALTER DATABASE OPEN;

1)SQL>SHUTDOWN NORMAL/IMMEDIATE;

2)SQL>START MOUNT;

3)SQL>ALTER DATABASE NOARCHIVELOG;

4)SQL>ALTER DATABASE OPEN;

3启用自动归档: LOG_ARCHIVE_START=TRUE

归档模式下,日志文件组不允许被覆盖(重写),当日志文件写满之后,如果没有进行手动归档,那么系统将挂起,知道归档完成为止

这时只能读而不能写

运行过程中关闭和重启归档日志进程

SQL>ARCHIVE LOG STOP

SQL>ARCHIVE LOG START

4手动归档: LOG_ARCHIVE_START=FALSE

归档当前日志文件

SQL>ALTER SYSTEM ARCHIVE LOG CURRENT;

归档序号为052的日志文件

SQL>ALTER SYSTEM ARCHIVE LOG SEQUENCE 052;

归档所有日志文件

SQL>ALTER SYSTEM ARCHIVE LOG ALL;

改变归档日志目标

SQL>ALTER SYSTEM ARCHIVE LOG CURRENT TO '&PATH';

5归档模式和非归档模式的转换

第4步的逆过程

6配置多个归档进程

Q:什么时候需要使用多个归档进程

A:如果归档过程会消耗大量的时间,那么可以启动多个归档进程,这是个动态参数,可以用ALTER SYSTEM动态修改

SQL>ALTER SYSTEM SET LOG_ARCHIVE_MAX_PROCESSES=10;

Oracle9i中最多可以指定10个归档进程

与归档进程有关的动态性能视图

v$bgprocess,v$archive_processes

7配置归档目标,多归档目标,远程归档目标,归档日志格式

归档目标 LOG_ARCHIVE_DEST_n

本地归档目标:

SQL>LOG_ARCHIVE_DEST_1 = "LOCATION=D:ORACLEARCHIVEDLOG";

远程归档目标:

SQL>LOG_ARCHIVE_DEST_2 = "SERVICE=STANDBY_DB1";

强制的归档目标,如果出错,600秒后重试:

SQL>ALTER SYSTEM SET LOG_ARCHIVE_DEST_4 = "LOCATION=E:ORACLEARCHIVEDLOG MANDATORY REOPEN=600";

可选的归档目标,如果出错,放弃归档:

SQL>ALTER SYSTEM SET LOG_ARCHIVE_DEST_3 = "LOCATION=E:ORACLEARCHIVEDLOG OPTIONAL";

归档目标状态:关闭归档目标和打开归档目标

关闭归档目标1

SQL>ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1 = DEFER

打开归档目标2

SQL>ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2 = ENABLE

归档日志格式

LOG_ARCHIVE_FORMAT

8获取归档日志信息

V$ARCHVIED_LOG

V$ARCHVIE_DEST

V$LOG_HISTORY

V$DATABASE

V$ARCHIVE_PROCESSES

ARCHIVE LOG LIST;

Sql代码

sql> archive log list; #查看是不是归档方式

sql> alter system set log_archive_start=true scope=spfile; #启用主动归档

sql> alter system set log_archive_dest=''location=/oracle/ora9/oradata/arch'' scope=spfile;#设置归档路径

sql> alter system set log_archive_dest_1=''location=/oracle/ora9/oradata/arch1'' scope=spfile;

sql> alter system set log_archive_dest_2=''location=/oracle/ora9/oradata/arch2'' scope=spfile;

#如果归档到两个位置,则可以通过上边方法实现

sql> alter system set log_archive_format=''arch_%d_%t_%r_%slog'' #设置归档日记款式

sql> shutdown immediate;

sql> startup mount; #打开控制文件,不打开数据文件

sql> alter database archivelog; #将数据库切换为归档模式

sql> alter database open; #将数据文件打开

sql> archive log list; #查看此时是否处于归档模式

查询以确定数据库位于archivelog模式中且归档过程正在运行

sql> select log_mode from v$database;

sql> select archiver from v$instance;

Sql代码

日志切换

sql> alter system switch logfile;

这次日志切换将归档写到两个目标地,

即上边的/oracle/ora9/oradata/arch1和/oracle/ora9/oradata/arch1,

要是要对目录确认

在oracle情况中运行如下查询:

sql> select name from v$archived_log;

而后在 *** 作系统中确认查询所列出的文件

二 设置非归档方式

Sql代码

sql> archive log list; #查看是否是归档方式

sql> alter system set log_archive_start=false scope=spfile;

#禁用自动归档

sql> shutdown immediate;

sql> startup mount; #打开控制文件,不打开数据文件

sql> alter database noarchivelog; #将数据库切换为非归档模式

sql> alter database open; #将数据文件打开

sql> archive log list; #查看此时便处于非归档模式

三 归档相关命令

Sql代码

archive log stop;

archive log start;

archive log list;

show parameters;

show parameters log_archive_start;

show parameters log_archive_max_process; #归档进程数

alter system set log_archive_max_process=5; #将归档进程数改为5

select from v$bgprocess; #检察后台进程

以上就是关于如何启动或关闭Oracle的归档模式全部的内容,包括:如何启动或关闭Oracle的归档模式、Oracle归档模式和非归档模式的区别、如何启动或关闭oracle的归档模式等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9431387.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存