06.Oracle数据备份与恢复

这篇具有很好参考价值的文章主要介绍了06.Oracle数据备份与恢复。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

oracle基础系统学习目录

01.CentOS7静默安装oracle11g
02.Oracle的启动过程
03.从简单的sql开始
04.Oracle的体系架构
05.Oracle数据库对象
06.Oracle数据备份与恢复
07.用户和权限管理
08.Oracle的表
09.Oracle表的分区
10.Oracle的同义词与序列
11.Oracle的视图
12.Oracle的索引
13.Oracle通过JDBC连接Java
14.Oracle中的事务
15.Oracle11g的归档方式和日志文件的相关操作
16.Oracle的数据字典和动态性能视图
17.Oracle11g的PL/SQL基础
18.Oracle的过程和函数
19.Oracle11g中的游标
20.Oracle11g中的触发器
21.Oracle的程序包(Package)
22.Oracle中的临时表空间
23.Oracle11g的UNDO表空间
24.Oracle11g的逻辑备份与恢复
25. Oracle的回收站
26.Oracle11g的数据装载
27.Oracle11g的闪回Flashback
28.Oracle11g物化视图


一、通过RMAN方式备份

通过 RMAN(Oracle 数据库备份和恢复管理器)方式备份 Oracle 数据库,可以使用以下步骤:

  1. 启动归档模式
    查看是否为存档模式:

    SQL> archive log list;
    Database log mode              No Archive Mode
    Automatic archival             Disabled
    Archive destination            USE_DB_RECOVERY_FILE_DEST
    Oldest online log sequence     11
    Current log sequence           13
    SQL>
    

    关闭数据库,并启动归档模式

    SQL> shutdown;
    Database closed.
    Database dismounted.
    ORACLE instance shut down.
    SQL> startup mount;
    ORACLE instance started.
    
    Total System Global Area 1286066176 bytes
    Fixed Size                  2213016 bytes
    Variable Size             352324456 bytes
    Database Buffers          922746880 bytes
    Redo Buffers                8781824 bytes
    Database mounted.
    SQL> alter database archivelog;
    
    Database altered.
    
    SQL>
    

    打开数据库,并查看是否修改成功

    SQL> archive log list;
    Database log mode              Archive Mode
    Automatic archival             Enabled
    Archive destination            USE_DB_RECOVERY_FILE_DEST
    Oldest online log sequence     11
    Next log sequence to archive   13
    Current log sequence           13
    SQL>
    

如果想在归档模式下进行备份,只能把数据库启动到mount状态下才可以进行
但在生产环境中,一般情况下数据库是不能随意进行关闭的,所以一般在安装好数据库之后直接就开启归档模式,更改归档需要在mount模式下

  1. 打开 RMAN 命令行界面:

    [oracle@localhost ~]$ rman target /
    
    Recovery Manager: Release 11.2.0.1.0 - Production on Fri Nov 3 17:58:54 2023
    
    Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved.
    
    connected to target database: ORCL (DBID=1679473799)
    
    RMAN>
    
  2. 开始备份
    (1) 使用backup database;对数据库直接备份

    RMAN> backup database;
    
    Starting backup at 03-NOV-23
    using target database control file instead of recovery catalog
    allocated channel: ORA_DISK_1
    channel ORA_DISK_1: SID=192 device type=DISK
    channel ORA_DISK_1: starting full datafile backup set
    channel ORA_DISK_1: specifying datafile(s) in backup set
    input datafile file number=00001 name=/u01/app/oracle/oradata/orcl/system01.dbf
    input datafile file number=00002 name=/u01/app/oracle/oradata/orcl/sysaux01.dbf
    input datafile file number=00003 name=/u01/app/oracle/oradata/orcl/undotbs01.dbf
    input datafile file number=00004 name=/u01/app/oracle/oradata/orcl/users01.dbf
    channel ORA_DISK_1: starting piece 1 at 03-NOV-23
    channel ORA_DISK_1: finished piece 1 at 03-NOV-23
    piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_nnndf_TAG20231103T194131_ln9q3d1w_.bkp tag=TAG20231103T194131 comment=NONE
    channel ORA_DISK_1: backup set complete, elapsed time: 00:00:15
    channel ORA_DISK_1: starting full datafile backup set
    channel ORA_DISK_1: specifying datafile(s) in backup set
    including current control file in backup set
    including current SPFILE in backup set
    channel ORA_DISK_1: starting piece 1 at 03-NOV-23
    channel ORA_DISK_1: finished piece 1 at 03-NOV-23
    piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_ncsnf_TAG20231103T194131_ln9q3wok_.bkp tag=TAG20231103T194131 comment=NONE
    channel ORA_DISK_1: backup set complete, elapsed time: 00:00:01
    Finished backup at 03-NOV-23
    
    RMAN>
    

    进入相关目录查看备份结果
    06.Oracle数据备份与恢复,oracle学习,oracle,数据库

    [oracle@localhost ~]$ cd /u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/
    [oracle@localhost 2023_11_03]$ ll
    total 1016728
    -rw-r----- 1 oracle oinstall    9830400 Nov  3 18:09 o1_mf_ncsnf_TAG20231103T180906_ln9kp3ff_.bkp
    -rw-r----- 1 oracle oinstall    9830400 Nov  3 19:25 o1_mf_ncsnf_TAG20231103T192501_ln9p4gqt_.bkp
    -rw-r----- 1 oracle oinstall    9830400 Nov  3 19:41 o1_mf_ncsnf_TAG20231103T194131_ln9q3wok_.bkp
    -rw-r----- 1 oracle oinstall 1011638272 Nov  3 19:41 o1_mf_nnndf_TAG20231103T194131_ln9q3d1w_.bkp
    [oracle@localhost 2023_11_03]$
    

    对数据进行恢复(恢复数据时数据库也需要处于mount状态下):

    run {
     set until time "to_date('11/22/2023 10:00:00','mm/dd/yyyy hh24:mi:ss')";
     restore database;
     recover database;
     alter database open resetlogs;
    }
    

    rman不但可以备份,也可以使用其进行管理,示例如下:
    06.Oracle数据备份与恢复,oracle学习,oracle,数据库
    (2)使用backup tablespace USERS;对表空间的备份和恢复

    RMAN> backup tablespace USERS;
    
    Starting backup at 03-NOV-23
    using channel ORA_DISK_1
    channel ORA_DISK_1: starting full datafile backup set
    channel ORA_DISK_1: specifying datafile(s) in backup set
    input datafile file number=00004 name=/u01/app/oracle/oradata/orcl/users01.dbf
    channel ORA_DISK_1: starting piece 1 at 03-NOV-23
    channel ORA_DISK_1: finished piece 1 at 03-NOV-23
    piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_nnndf_TAG20231103T223829_lnb1h5d1_.bkp tag=TAG20231103T223829 comment=NONE
    channel ORA_DISK_1: backup set complete, elapsed time: 00:00:01
    Finished backup at 03-NOV-23
    
    RMAN>
    

    若表空间已损毁恢复,需要恢复表空间可以先使用restore tablespace USERS;再使用recover tablespace USERS;
    (3)使用backup archivelog all;对归档日志进行备份

    RMAN> backup archivelog all;
    
    Starting backup at 07-NOV-23
    current log archived
    using channel ORA_DISK_1
    channel ORA_DISK_1: starting archived log backup set
    channel ORA_DISK_1: specifying archived log(s) in backup set
    input archived log thread=1 sequence=13 RECID=1 STAMP=1152203517
    input archived log thread=1 sequence=14 RECID=2 STAMP=1152231422
    channel ORA_DISK_1: starting piece 1 at 07-NOV-23
    channel ORA_DISK_1: finished piece 1 at 07-NOV-23
    piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_07/o1_mf_annnn_TAG20231107T001702_lnl4cy94_.bkp tag=TAG20231107T001702 comment=NONE
    channel ORA_DISK_1: backup set complete, elapsed time: 00:00:01
    Finished backup at 07-NOV-23
    
    使用 `CROSSCHECK BACKUP` 命令验证备份的完整性。RMAN 将检查备份文件的状态,并将其标记为“EXPIRED”(过期)或“AVAILABLE”(可用)。
    

    示例如下:

    RMAN> crosscheck backup;
    
    using channel ORA_DISK_1
    crosschecked backup piece: found to be 'AVAILABLE'
    backup piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_ncsnf_TAG20231103T180906_ln9kp3ff_.bkp RECID=1 STAMP=1151950147
    crosschecked backup piece: found to be 'AVAILABLE'
    backup piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_ncsnf_TAG20231103T192501_ln9p4gqt_.bkp RECID=2 STAMP=1151954702
    crosschecked backup piece: found to be 'AVAILABLE'
    backup piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_nnndf_TAG20231103T194131_ln9q3d1w_.bkp RECID=3 STAMP=1151955692
    crosschecked backup piece: found to be 'AVAILABLE'
    backup piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_ncsnf_TAG20231103T194131_ln9q3wok_.bkp RECID=4 STAMP=1151955708
    crosschecked backup piece: found to be 'AVAILABLE'
    backup piece handle=/u01/app/oracle/flash_recovery_area/ORCL/backupset/2023_11_03/o1_mf_nnndf_TAG20231103T223829_lnb1h5d1_.bkp RECID=5 STAMP=1151966309
    Crosschecked 5 objects
    
    
    RMAN>
    

二、使用emp/imp和expdb/impdb工具进行备份和恢复

emp/imp是Oracle传统的备份和恢复工具,它们使用二进制格式将数据导出和导入。
expdb/impdb是Oracle 10g及以上版本引入的新工具,它们使用XML格式将数据导出和导入。
下面我们将详细讲解如何使用这些工具进行备份和恢复。
  1. 使用emp/imp进行备份和恢复

    emp和imp命令用于将Oracle数据库中的数据导出到一个文件中,以便进行备份或迁移。它们可以将整个数据库或单个表导出到一个文件中,然后再将文件导入到另一个数据库中。

    备份数据:

    exp userid=username/password file=d:\backup\emp_backup.dmp full=y
    

    上述命令将整个数据库导出到d:\backup\emp_backup.dmp文件中。

    恢复数据:

    imp userid=username/password file=d:\backup\emp_backup.dmp full=y
    

    上述命令将d:\backup\emp_backup.dmp文件中的数据导入到数据库中。

  2. 使用expdb/impdb进行备份和恢复

    expdb和impdb命令是Oracle 10g及以上版本引入的新工具,它们使用XML格式将数据导出和导入。它们的使用方法与emp/imp相似。

    备份数据:

    expdp userid=username/password directory=backup_dir dumpfile=expdb_backup.dmp full=y
    

    上述命令将整个数据库导出到backup_dir目录下的expdb_backup.dmp文件中。

    恢复数据:

    impdp userid=username/password directory=backup_dir dumpfile=expdb_backup.dmp full=y
    

    上述命令将backup_dir目录下的expdb_backup.dmp文件中的数据导入到数据库中。

三、使用Data guard进行备份与恢复

Oracle Data Guard是Oracle数据库提供的一种高可用性解决方案,它可以实现数据备份和恢复的功能。它通过将主数据库的数据实时复制到一个或多个备用数据库,以提供数据冗余和灾难恢复能力。

下面是使用Data Guard进行备份和恢复的详细讲解:

  1. 配置Data Guard

    首先,需要在主数据库和备用数据库上配置Data Guard。在主数据库上进行以下操作:

    • 启用归档模式:ALTER DATABASE ARCHIVELOG;

    • 配置日志传输服务:ALTER SYSTEM SET LOG_ARCHIVE_DEST_2='SERVICE=standby_db ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=standby_db';

    在备用数据库上进行以下操作:

    • 启用归档模式:ALTER DATABASE ARCHIVELOG;

    • 配置日志应用服务:ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT;

  2. 启动Data Guard

    在主数据库上启动Data Guard:

    • 启动日志传输服务:ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2=ENABLE;

    在备用数据库上启动Data Guard:

    • 启动日志应用服务:ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT;
  3. 数据备份和恢复

    在Data Guard配置完成后,主数据库上的数据将实时复制到备用数据库。如果主数据库发生故障,可以使用备用数据库进行数据恢复。

    备份数据:

    • 在备用数据库上创建备份:RMAN> BACKUP DATABASE;

    恢复数据:

    • 在备用数据库上进行故障切换:ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;

    • 将备用数据库切换为主数据库:ALTER DATABASE ACTIVATE STANDBY DATABASE;

    • 在新的备用数据库上进行数据恢复:ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT;文章来源地址https://www.toymoban.com/news/detail-744669.html

点击此处跳转下一节:07.用户和权限管理

到了这里,关于06.Oracle数据备份与恢复的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • oracle19c容器数据库rman备份特性-----性能优化(三)

    目录 冗余备份片 1.备份的时候指定 2.rman配置中设定 归档备份(将备份集保留) 二级备份(将备份文件保留) 1.备份闪回恢复区的恢复文件 2.备份所有恢复文件 recovery catalog database 1.創建recovery catalog 2.创建VPC  data recovery advisor 备份 如果一个数据文件很大,可以设置多通道并

    2024年02月01日
    浏览(56)
  • openGauss学习笔记-149 openGauss 数据库运维-备份与恢复-逻辑备份与恢复之gs_restore

    149.1 背景信息 gs_restore是openGauss提供的针对gs_dump导出数据的导入工具。通过此工具可由gs_dump生成的导出文件进行导入。 gs_restore工具由操作系统用户omm执行。 主要功能包含: 导入到数据库 如果连接参数中指定了数据库,则数据将被导入到指定的数据库中。其中,并行导入必

    2024年02月04日
    浏览(51)
  • 如何备份与恢复MySQL数据库数据

    目录 一、MySQL备份 备份方式 完全备份 差异备份 增量备份 二、常见的备份方法 物理冷备 专用备份工具 mysqldump 或 mysqlhotcopy 启用二进制日志进行增量备份 第三方工具备份 三、MySQL完全备份 四、数据库完全备份分类 物理冷备份与恢复 mysqldump备份与恢复 五、物理冷备份与恢复

    2024年02月16日
    浏览(73)
  • 数据库运维——备份恢复

    数据库备份,数据库为school,素材如下 1.创建student和score表 CREATE  TABLE  student ( id  INT(10)  NOT NULL  UNIQUE  PRIMARY KEY  , name  VARCHAR(20)  NOT NULL , sex  VARCHAR(4)  , birth  YEAR, department  VARCHAR(20) , address  VARCHAR(50)  ); 创建score表。SQL代码如下: CREATE  TABLE  score ( id  INT(10)  NOT NU

    2024年02月16日
    浏览(66)
  • 9-MySQL数据库 数据的备份与恢复

    1.date文件的备份 2.mysqldump 备份 说明: mysqldump是MySQL数据库中的一个实用程序,它主要用于转储(备份)数据库。mysqldump通过生成一个SQL脚本文件,包含从头开始重新创建数据库所必需的(如 CREATE TABLE和INSERT等),来实现数据库的备份和转储。这样,你可以在任何时候通过运

    2024年02月08日
    浏览(72)
  • 数据库实验7---数据库的备份与恢复

    使用mysqldump命令备份数据库studentsdb的所有表,存于D:下,文件名为all_tables.sql。 在MySQL服务器上创建数据库student1,使用mysql命令将备份文件all_tables.sql恢复到数据库student1中。 使用mysqldump命令备份数据库studentsdb的所有表,存于D:下,文件名为s_c.sql。 在MySQL服务器上创建数据

    2024年02月09日
    浏览(62)
  • mysql数据库备份和恢复

    数据备份可以分为三种, 热备份。 数据库处于运行状态,此时依赖数据库的日志文件进行备份 温备份。 进行数据备份时数据库服务正常进行,但是数据智能度不能写。 冷备份。数据库处于关闭状态,能够够好的保证数据库的完整性。 逻辑备份。使用软件从数据库中提取数

    2024年02月12日
    浏览(67)
  • MySQL数据库备份与恢复

    在项目的开发过程中数据库的备份是非常重要的,为了防止数据库受到破坏,造成不可估量的损失,所以一定要进行数据库的备份,并且需要掌握数据库恢复方法,在发生数据库损坏的时候,能快速进行数据库恢复。 本文主要介绍MySQL数据表备份与恢复主要的三种方法,包括

    2024年02月12日
    浏览(169)
  • 数据库(MySQL的备份和恢复)

    目录 1.1 MySQL 日志管理 1.1.1 MySQL日志类型 1.1.2 错误日志 错误日志中主要记录的几种日志 错误日志的定义 1.1.3 通用查询日志 1.1.4 慢查询日志 和慢查询相关的变量设置 1.1.5 二进制日志 二进制日志是记录执行的语句还是执行后的数据 日志滚动  1.2 MySQL备份 1.2.1 备份类型 1.2.2

    2024年01月25日
    浏览(64)
  • Mysql数据库增量备份与恢复

    使用 mysqldump 进行完全备份,备份的数据中有重复数据,备份时间与恢复时间长。 而增量备份就是备份自上一次备份之后增加或改变的文件或内容。 1、增量备份的特点: 没有重复数据,备份量不大,时间短 恢复麻烦:需要上次完全备份及完全备份之后所有的增量备份才能恢复

    2024年02月07日
    浏览(91)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包