1、首先查看当前数据库是否处于归档模式
可使用如下两种方式查看
1.1
select name, log_mode from v$database;
data:image/s3,"s3://crabby-images/d549b/d549bd7d019af910e7aa715a013b7ba49e883b6e" alt="技术分享图片"
log_mode的值为 NOARCHIVELOG 表示数据库处于非归档模式
data:image/s3,"s3://crabby-images/63154/631549d44e60577a87430b43ac11c426f3fb5d86" alt="技术分享图片"
log_mode的值为 ARCHIVELOG 表示数据库处于归档模式
1.2
archive log list; (此方法需要 as sysdba)
data:image/s3,"s3://crabby-images/eb285/eb2859c746f112ee936ca1de0cb687a82ab13814" alt="技术分享图片"
Database log mode 的值为 No Archive Mode
Automatic archival 的值为 Disabled
表示当前数据库处于非归档模式
data:image/s3,"s3://crabby-images/e216e/e216e202674b1a47911d1ee45878b426af0800d5" alt="技术分享图片"
Database log mode 的值为 Archive Mode
Automatic archival 的值为 Enabled
表示数据库已开启归档模式
2、非归档模式的数据库更改为归档模式
数据库从非归档模式更改为归档模式需要数据库处于mount状态下。
以下操作适用于oracle10g以上版本,对于oracle8i和9i不适用。
2.1 关闭数据库
shutdown immediate;
data:image/s3,"s3://crabby-images/5bbe7/5bbe74ca2e89a04a257cd698438f97f71b56f8bf" alt="技术分享图片"
2.2 启动数据库到mount状态
startup mount;
data:image/s3,"s3://crabby-images/76f45/76f4549613305e11c2a51de648967044a91f5029" alt="技术分享图片"
2.3 修改数据库为归档模式
alter database archivelog;
data:image/s3,"s3://crabby-images/42261/422614f99669b8e973d7b107cdf0bdd7396ac747" alt="技术分享图片"
2.4 打开数据库
alter database open;
data:image/s3,"s3://crabby-images/39bf8/39bf8725efb9b7b6da34bc3d8ee81522f5abb58f" alt="技术分享图片"
2.5 查询数据库是否已处于归档模式
archive log list;
data:image/s3,"s3://crabby-images/b5d4e/b5d4e658f88ba06b4ed7683e44335403070df4b7" alt="技术分享图片"
数据库已由非归档模式更改为归档模式
2.6 修改日志文件命名格式
alter system set log_archive_max_processes = 5;
alter system set log_archive_format = "archive_%t_%s_%r.log" scope=spfile;
data:image/s3,"s3://crabby-images/c7697/c769756ddad15e1c3042fb0d11b7b7210b1043cd" alt="技术分享图片"
此处修改后如果重启,则重启后归档的日志文件格式会更改为 archive_%t_%s_%r.log 格式,否则仍是默认的格式。
2.7 更改日志文件路径
alter system set log_archive_dest_1=‘location=/data/archivelog/orcl‘;
data:image/s3,"s3://crabby-images/44e2a/44e2a8687751a30012fd57b9a8bf9afcc2c9f84d" alt="技术分享图片"
此时 Archive destination的值更改为 /data/archivelog/orcl
该语句含义是确定归档日志的路径,实际上Oracle 10g以后可以生成多份一样的日志,保存多个位置,以防不测
例如再添加一个日志位置可使用以下语句
SQL>alter system set log_archive_dest_2=‘location=/bak/orcl/archive_log‘;
2.8 归档当前重做日志
select name from v$archived_log;
alter system archive log current;
data:image/s3,"s3://crabby-images/78aab/78aabe267d4267add7f8480e10bd01c368dbfe4f" alt="技术分享图片"
可以看出在归档当前重做日志后从v$archived_log中能查到当前被归档的重做日志,由于没有重启数据库,所以归档日志的文件格式仍然是默认的格式。
注:
<
alter system switch logfile 是强制日志切换,不一定就归档当前的重做日志文件(若自动归档打开,就归档前的重做日志,若自动归档没有打开,就不归档当前重做日志。)
alter system archive log current 是归档当前的重做日志文件,不管自动归档有没有打都归档。
主要的区别在于:
alter system switch logfile 对单实例数据库或RAC中的当前实例执行日志切换;
alter system archive log current 会对数据库中的所有实例执行日志切换。
>
2.9 重启数据库
shutdown immediate;
startup
data:image/s3,"s3://crabby-images/0bbe6/0bbe69f7d4666c2c77e1fe5f7e555cd0dff33734" alt="技术分享图片"
2.10 查询归档信息
archive log list;
data:image/s3,"s3://crabby-images/20893/208931ed5ec555f26935c8a8780942bbeec8717b" alt="技术分享图片"
数据库由非归档模式更改为归档模式
3、归档模式的数据库更改为非归档模式
数据库从非归档模式更改为归档模式需要数据库处于mount状态下。
以下操作适用于oracle10g以上版本,对于oracle8i和9i不适用。
3.1
关闭数据库
如果数据库处于打开状态则需要先关闭数据库,如果数据库处于关闭状态,则直接执行3.2步即可。
关闭数据库之前归档当前重做日志
alter system archive log current;
shutdown immediate;
data:image/s3,"s3://crabby-images/00b00/00b00f7b9e12786ed78c119a8bc0cade5819ccab" alt="技术分享图片"
3.2 启动数据库到mount状态
startup mount;
data:image/s3,"s3://crabby-images/3d78e/3d78ebbafcd9c31ee62d277ae3b50d4a4d377fc4" alt="技术分享图片"
3.3 查看的数据库的归档信息
archive log list;
或者
select name, log_mode from v$database;
data:image/s3,"s3://crabby-images/56ecd/56ecd7dafba21ed340b972500bae7cbe3719d408" alt="技术分享图片"
3.4 更改归档模式为非归档模式
alter database noarchivelog;
data:image/s3,"s3://crabby-images/1dcf5/1dcf591b5784bc9041d7d7bc5f91cc494cb36dcc" alt="技术分享图片"
3.4 查看的数据库的归档信息
archive log list;
或者
select name, log_mode from v$database;
data:image/s3,"s3://crabby-images/3e9bc/3e9bc709028df84e6d98d0526db8c5bab91cf4ae" alt="技术分享图片"
3.5 打开数据库
alter database open;
data:image/s3,"s3://crabby-images/e9954/e995414771945dd80cf330860a00fa63be2bd5dc" alt="技术分享图片"
数据库由归档模式更改为非归档模式