百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Oracle数据库的备份与恢复,实用易学简单,转发收藏备用

gudong366 2025-03-20 10:46 10 浏览

Oracle数据库非常强大,有其自己的备份与恢复机制,并且细分,只要配置合理,完全可以保证数据库的完整,免去运维人员的后顾之忧。

Oracle数据库使用RMAN备份,需要把数据库的非归档模式改成归档模式。

数据库的备份

一、更改数据库的归档模式需要重新启动数据库,在mount模式下修改(三种启动模式nomount---mount--- open)。

具体步骤如下:

1、进入数据库后,关闭数据库

SQL>shutdown immediate

2、启动数据库到mount状态

SQL>startup mount

3、改变数据库为归档模式

SQL>alter database archivelog;(归档改为非归档语句为alter database noarchivelog;)

4、验证方式

SQL>alter database open;(打开数据库)

SQL>archive log list

二、启动控制文件的自动备份

RMAN>configure controlfile autobackup on;

RMAN>show controlfile autobackup ;(验证)

三、全库备份

3.1最简单的全库备份

RMAN>backup database;

RMAN>list backup;(验证)

RMAN>list backup summary;(验证)

四、脚本备份

4.1查看linux系统oracle用户的环境变量,从而知道需要备份数据库的名称和实例

$ cat /home/oracle/.bash_profile

主要看ORACLE_SID=orcl

4.2在RMAN中设置冗余数(备份的次数,根据需要,一次备份的数据大小,备份的磁盘空间大小来决定)。

$ rman target/

RMAN>configure retenticn policy to redundancy 10;(这里设置为10次)

4.3规划备份的目录


/usr/local/oradata/orcl/RmanBackup,如果没有,创建即可,这里需要注意这个文件夹必须属于oracle用户。

4.4全量备份脚本如下图

这个0级全量备份脚本需要在oracle用户下执行,并且需要把脚本chmod为775权限。

export ORACLE_BASE=/usr/local/oracle

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1

export ORACLE_SID=orcl

export PATH=$PATH:$ORACLE_HOME/bin:$HOME/bin

rman target/ << EOF_RMAN

run{

allocate channel c1 type disk;

backup incremental level 0 tag 'db0' format

'/usr/local/oradata/orcl/RmanBackup/db0_%d_%U' database include current controlfile;

delete noprompt obsolete;

release channel c1;

}

#end

把以上脚本放置到crontab中,可以设置自动执行。

4.3增量备份脚本

export ORACLE_BASE=/usr/local/oracle

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1

export ORACLE_SID=orcl

export PATH=$PATH:$ORACLE_HOME/bin:$HOME/bin

rman target/ << EOF_RMAN

run{

allocate channel c1 type disk;

backup incremental level 1 tag 'db1' format

/usr/local/oradata/orcl/RmanBackup/db1_%d_%T_%s' database include current controlfile;

delete noprompt obsolete;

release channel c1;

}

#end

Oracle数据库的恢复(一)

Oracle数据库的恢复需要在oracle用户下执行,恢复内容包括控制文件*.ctl,重组日志文件*.log,数据库文件*.dbf。

一、恢复dbf文件

前提条件是Oracle数据库的初始化spfile文件,控制文件、重组日志文件、归档日志、备份都可以正常使用。

现在先删除dbf文件。

1、关闭数据库,再重新数据库,进入数据库

1.1 $ sqlplul / as sysdba

SQL>shutdown immediate(无法正常关闭,原因是没有数据库文件)

SQL>shutdown abort(强制关闭)

1.2 SQL>startup(无法正常启动,原因是没有数据库文件)

1.3恢复

$ rman target/

Oracle数据库没有处于open状态,这是因为数据库找不到数据文件,所以目前的数据库处于mount状态。

1.3.1 还原文件

RMAN> restore database;

1.3.2验证

进入存放dbf文件的目录查看,dfb文件已经被恢复。

1.3.3继续恢复数据

RMAN> recover database;

1.3.4打开数据库的open状态

RMAN> sql 'alter database open';

恢复完成,下面退出oracle数据库的rman环境,重新进入数据库。

[oracle@shell ~]$ sqlplus / as sysdba

SQL> select instance_name,status from v$instance;

查看重做日志文件是否为原来的重做日志文件

SQL> archive log list;

由上图显示,数据库的重做日志的序号没有从1开始,证明还是原来的重做日志。数据库进行了完全恢复。

恢复成功后,最好立刻备份数据。

二、重做日志文件损坏的恢复

2.1确定数据库的备份状态

必须是oracle用户,执行rman target/

查看数据库备份信息

2.2删除重做日志文件

2.3重做日志

$sqlplus / as sysdba

SQL> alter system switch logfile;

数据库会报错

这里第一行主要出现

ORA-01034: ORACLE not available的错误

此时可以重新启动到mount状态

SQL> startup mount;

继续恢复

SQL> alter database open resetlogs;

SQL> select * from v$log;

SQL> alter database open resetlogs;

第一行出现错误,ORA-01139:RESETLOGS选项仅在不完全数据库恢复后有效。

SQL> recover database until time '2021-06-16 09:09:09';

完成介质恢复。把数据恢复到6月19日9点09分09秒。

SQL> alter database open resetlogs;

数据库已经更改

SQL> shutdown

数据库已经关闭。

已经卸载数据库。

ORACLE例程已经关闭。

SQL> startup

ORACLE实例已经启动。

数据库装载完毕。

数据库已经打开。

SQL> select instance_name,status from v$instance;

查看文件.log文件在/usr/local/oradata/orcl目录下

相关推荐

U盘文件被删怎么简单恢复(u盘里的文件被误删了怎么找回)

现在这个社会不是靠关系靠路子,主要还是靠实力。刘强在机关工作,人长得帅气,工作能力又强。唯独一样不好,脾气太大,动不动就发火,因为小事常和同事发生口角。一次他火大的差点把办公桌给掀翻了,领导见他野蛮的...

不小心删除了一些文件?9 个最佳免费硬盘恢复软件

恢复您曾经无意或意外删除的所有文件和数据。您是否曾经错误地删除了一个对您的工作至关重要并导致您丢失所有进度的文件?我们为您提供了一些最好的免费硬盘恢复软件,以帮助您恢复意外删除的文件,以解决您的文件删...

Studio 中文版:数据救援神器,误删 / 分区损坏 / RAID 恢复一键找回

Studio中文版:数据救援神器,误删/分区损坏/RAID恢复一键找回当文件意外删除、分区损坏,或RAID阵列崩溃时,一款可靠的数据恢复工具往往能挽回关键损失。R-Studio中文版...

你值得拥有的11款Linux数据恢复工具

如果你使用的是Linux操作系统,那么你一定想知道一旦硬盘崩溃的话又该如何保存和恢复数据。其实,现在有很多Linux数据恢复工具可以让我们摆脱数据安全的困扰。小编已经为各位准备好了一些最好的Linux...

误删文件内容怎么恢复(误删文件内容怎么恢复回来)

  在日常使用电脑的过程中,误删文件的情况时有发生。无论是由于操作失误还是病毒攻击,误删文件都会给我们带来不小的困扰。幸运的是,随着技术的发展,误删文件恢复已不再是难题。本文将介绍几款国内外知名的误删...

u盘如何恢复删除的文件?推荐5款u盘数据恢复软件!

在日常生活与工作中,U盘作为便捷的数据存储载体,频繁用于传输和保存各类重要文件。然而,误删文件的情况却时有发生,无论是珍贵的照片、重要的工作文档,还是精心制作的视频,一旦删除,都可能带来不小的麻烦。...

怎么恢复删除的数据?5种有效的数据恢复方法汇总!

在数字化办公与生活的时代,电脑里的每一份数据都承载着重要信息。然而,一个误操作就可能导致数据被删除,无论是尚未保存的重要文档,还是珍藏多年的照片,都可能瞬间“消失”。但其实,数据删除并不意味着永久丢...

u盘删除文件怎么找回?5个数据恢复工具汇总,助你巧妙恢复数据!

在日常使用U盘的过程中,误删文件的情况时有发生,重要的工作文档、珍贵的照片视频一旦消失,难免让人焦急万分。别担心,只要选对数据恢复工具,被删除的数据仍有找回的可能。下面就为你汇总5款实用的数据...

Linux下恢复误删文件:思路+实践(linux删除如何恢复)

周五篮球群里有人问误删文件了怎么恢复,得知是ext4文件系统之后我推荐了ext4magic这个工具,然后又有人提到了xfs的话怎么办,正好前几天看到DaveChinner在邮件列表里提到了这个问题,...

苹果放大招!不用虚拟机了,Mac直接跑Linux容器,开发者效率翻倍

苹果这次真给开发者送福利了!今天凌晨(6月10日),苹果在官宣的Containerization框架直接炸了技术圈——Mac现在能原生运行Linux容器镜像了!这可不是虚拟机那种“套娃”方案,而是基...

7 款老牌经典软件,值得收藏(经典老歌软件)

Calibrehttps://calibre-ebook.com/Calibre是一个电脑电子书管理软件。肯定有人说了,电子书还要管理?那当然了。它的功能更强大的让你想象不到,首先它可以导入PDF,...

神仙级的免费开源电子书阅读器,还支持听书功能

神仙级的免费开源电子书阅读器,还支持听书功能,极空间部署『KoodoReader』哈喽小伙伴们好,我是Stark-C~前段时间不是给大家分享的电子书管理工具『TaleBook』嘛~,然后就有粉丝私信...

如何在Ubuntu系统中重置root密码(ubuntu忘记密码重置root密码命令)

很多人有个问题,就是喜欢把密码设置得很长很复杂,结果谁也没防住,却成功防住了自己ヽ(.ˇдˇ;)ノ对于现代人,特别是年轻人,都有过忘记密码的经历吧。在这篇文章中,我们来了解如何在Ubuntu1...

5款功能强大的PDF阅读器,让PDF阅读更轻松

分享5款功能强大的PDF阅读器,拥有丰富的PDF阅读工具,支持PDF文档划线、笔记、标记等操作,让PDF阅读更轻松!1.嗨动PDF编辑器一款实用的PDF处理软件,不仅可以阅读PDF文档,还能直接编辑、...

上班摸鱼利器! 免费好用的电子书阅读器,NAS轻松部署Koodo Reader

哈喽,大家好我是生活爱好者。笔者也是一名小说爱好者,平时用手机用某信读书,会员也开了,在家看体验也不错,但是上班的时候,在工作快速完成之后,想摸个鱼用手机就不太方便啦,作为爱折腾的人,必须要工作认真,...