基于Linux下 Oracle 备份策略(RMAN)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: --********************************** -- 基于Linux下 Oracle 备份策略(RMAN) --**********************************       对于 Oracle 数据库的备份与恢复,尽管存在热备,冷备以及逻辑备份之外,使用最多的莫过于使用RMAN进行备份与恢复。

--**********************************

-- 基于Linux Oracle 备份策略(RMAN)

--**********************************

 

    Oracle 备份与管存在热备,冷以及逻辑备份之外,使用最多的莫于使用RMAN备份与。而制定RMAN备份

是基于库丢失的容忍程度,即恢策略制定。在下面的备份策略中,出的是一通用的备份策略。在该备份策略中,使用了catalog

保持备份本以及备份信息。在实际环境中根据具体的情况对行相整。

 

一、步

    1.认备份可用空以及备份,根据需要建相文件

   

    1.账户建一connect.rcv文件包含接到target catalog信息

   

    2.建通用的脚本用于过旧备份备份控制文件以及备份归档日志

        global_del_obso      --过旧备份

        global_bkctl         --备份控制文件

        global_arch          --备份归档日志

   

    3.0,1,2增量备份

        脚本中均包含第2步的3脚本,先global_del,然后做增量备份,最后备份归档日志global_arch和控制文件global_bkctl

       

    4.inc0.rcv,inc1.rcv,inc2.rcv

        文件容包含 @@/<dir>/connect.rcv以及run{execute global script scriptname;}exit;

       

    5.编辑4步的三文件分别为inc0.sh,inc1.sh,inc2.sh

        nohup  $ORACLE_HOME/bin/rman  cmdfile=/u03/bk/scripts/inc1.rcv log=/u03/bk/scripts/inc0.log append &

   

    6.使用crontab制定备份计划   

 

二、具体实现

    演示境:

                    CentOS release 4.6 (Final) + Oracle 10g

        标数      austin

        录数:   david

        备份        /u03/bk

        接脚本所在路/u03/bk/scripts

        注:听需要配置好且已启动

   

    1.接脚本

        connect.rcv文件

            connect catalog rman/rman@david;

            connect target sys/oracle@austin;

        catalog的通用脚本

            rman cmdfile=/u03/bk/scripts/connect.rcv --(rman中使用外部脚本)

            rman catalog rman/rman@david target sys/oracle@austin   --使用脚本接后建通用脚本

 

    2.建立通用脚本

        --除不必要的备份

            RMAN> create global script global_del_obso  comment 'A script for obsolete backup and delete it' {

            2> crosscheck archivelog all;

            3> delete noprompt expired archivelog all;

            4> allocate channel ch1 device type disk;

            5> delete noprompt obsolete recovery window of 7 days; 

            6> release channel ch1;

            7> }

       

        --备份控制文件脚本

            RMAN> create global script global_bkctl comment 'A script for backup control file'{

            2> allocate channel ch1 device type disk;

            3> backup as compressed backupset

            4> current controlfile reuse

            5> format='/u03/bk/backupctl.ctl'

            6> tag='bkctl';

            7> release channel ch1;

            8> }

       

        --备份归档日志脚本

            RMAN> create global script global_arch comment "backup archivelog and then delete it" {

            2> allocate channel ch1 device type disk;

            3> allocate channel ch2 device type disk;

            4> sql "alter system archive log current";    --归档当前的机日志

            5> set limit channel ch1 readrate=10240;        --(取速率10M)            

            6> set limit channel ch1 kbytes=4096000;        --(备份片的大)   

            7> backup as compressed backupset

            8> format='/u03/bk/arch_%d_%U'

            9> tag='bkarch'

            10> archivelog all delete input;

            11> release channel ch1;

            12> release channel ch2;

            13> }

       

        --使用list看所有的已建立的全局脚本

            list global script names;               --(列出所有的脚本)

            delete globals script script_name;      --(除脚本)

           

            RMAN> list global script names;

 

            List of Stored Scripts in Recovery Catalog

                        

                Global Scripts

                        

                   Script Name

                   Description

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

                   global_arch

                   backup archivelog and then delete it

           

                   global_bkctl

                   A script for backup control file

            

                   global_del_obso

                   A script for obsolete backup and delete it

   

    3.012增量备份脚本(注:每脚本备份会执过旧备份,脚本尾部会调用另外两个脚本来备份归档日志及控制文件)

        --0增量备份

            RMAN> create global script global_inc0 comment "backup database as incrmental level 0"{

            2> execute global script global_del_obso;

            3> allocate channel ch1 device type disk;

            4> allocate channel ch2 device type disk;

            5> set limit channel ch1 readrate=10240;

            6> set limit channel ch1 kbytes=4096000;

            7> set limit channel ch2 readrate=10240;

            8> set limit channel ch2 kbytes=4096000;

            9> backup as compressed backupset

            10> incremental level 0 database

            11> format='/u03/bk/inc0_%d_%U'

            12> tag='inc0';

            13> release channel ch1;

            14> release channel ch2;

            15> execute global script global_arch;

            16> execute global script global_bkctl;

            17> }

           

        --1增量备份       

            RMAN> create global script global_inc1 comment "backup database as incrmental level 1"{

            2> execute global script global_del_obso;

            3> allocate channel ch1 device type disk;

            4> allocate channel ch2 device type disk;

            5> set limit channel ch1 readrate=10240;

            6> set limit channel ch1 kbytes=4096000;

            7> set limit channel ch2 readrate=10240;

            8> set limit channel ch2 kbytes=4096000;

            9> backup as compressed backupset

            10> incremental level 1 database

            11> format='/u03/bk/inc1_%d_%U'

            12> tag='inc1';

            13> release channel ch1;

            14> release channel ch2;

            15> execute global script global_arch;

            16> execute global script global_bkctl;

            17> }

 

        --2增量备份       

            RMAN> create global script global_inc2 comment "backup database as incrmental level 2"{

            2> execute global script global_del_obso;

            3> allocate channel ch1 device type disk;

            4> allocate channel ch2 device type disk;

            5> set limit channel ch1 readrate=10240;

            6> set limit channel ch1 kbytes=4096000;

            7> set limit channel ch2 readrate=10240;

            8> set limit channel ch2 kbytes=4096000;

            9> backup as compressed backupset

            10> incremental level 2 database

            11> format='/u03/bk/inc2_%d_%U'

            12> tag='inc2';

            13> release channel ch1;

            14> release channel ch2;

            15> execute global script global_arch;

            16> execute global script global_bkctl;

            17> }

       

        --rman检验rman的脚本global_inc0global_inc1global_inc2,RMAN动检查,下面的句用来执行脚本(检验)

            RMAN> run{

            2> execute global script global_inc0;

            3> execute global script global_inc1;

            4> execute global script global_inc2;

            5> }

       

        --备份成情

            list backupset summary;

 

    4.建立shell脚本,linux动执行脚本

        a. vi inc0.rcvinc1.rcv ,inc2.rcv   --注意不同的文件行不同的备份脚本

            @@/u03/bk/scripts/connect.rcv       --(rman下的脚本去用其他脚本用@@)(用脚本不需要分)

            run{

            execute global script gloal_inc0;

            }

            exit;

    

        b. 编辑shell文件   

            vi inc0.sh

                nohup  $ORACLE_HOME/bin/rman  cmdfile=/u03/bk/scripts/inc0.rcv log=/u03/bk/scripts/inc0.log append &

            vi inc1.sh

                nohup  $ORACLE_HOME/bin/rman  cmdfile=/u03/bk/scripts/inc1.rcv log=/u03/bk/scripts/inc0.log append &

            vi inc2.sh

                nohup  $ORACLE_HOME/bin/rman  cmdfile=/u03/bk/scripts/inc2.rcv log=/u03/bk/scripts/inc0.log append &

       

            --注意:nohup&表示脚本放入后台

    

        c.使用crontab建立一个备份计划

        crontab -e  

            #min    hour    date  mon  day(星期)    command

            30        1      *     *    0           /u03/bk/scripts/inc0.sh

            30        1      *     *    1           /u03/bk/scripts/inc2.sh

            30        1      *     *    2           /u03/bk/scripts/inc2.sh

            30        1      *     *    3           /u03/bk/scripts/inc2.sh

            30        1      *     *    4           /u03/bk/scripts/inc1.sh

            30        1      *     *    5           /u03/bk/scripts/inc2.sh

            30        1      *     *    6           /u03/bk/scripts/inc2.sh

       

        d.crontab(如果启动)

            # /sbin/service crond status  --用于检查crontab 务状态

            # /sbin/service crond stop //关闭

            # /sbin/service crond restart //

            # /sbin/service crond reload //重新入配置

           

            使crontab在系统启动候自动启动

                /etc/rc.d/rc.local这个脚本的末尾加上:

                /sbin/service crond start

 

        e.上面的备份策略看,即

            周日0增量备份,相于全

            周一,周二,周三2增量备份

            周四1增量备份

            周五,周六2增量备份

   

        f.编辑好的shell 脚本测试

            chmod 755 *.sh         --shell脚本加

            测试脚本  例如./inc0.sh

       

三、总结

    1.backup controlfile in each scripts tail (在脚本的尾部备份控制文件)

    2.Delete obsolete backupset in each scripts threshold (备份)

    3.Switch logfile before backup database; (库备份以前切志,备份联机重做日志)

    4.Chmod u+x*.sh

 

    本文根据德哥RMAN:Oracle一周备份方案的设计 整理完成

四、 快捷参考

性能请参

    Oracle 硬解析与软解析

    共享池的与优(Shared pool Tuning)

    Buffer cache 与优(一)

    Oracle (caching table)的使用

 

ORACLE体系结构请参

    Oracle 表空间与数据文件

    Oracle 文件

    Oracle 参数文件

    Oracle 机重做日志文件(ONLINE LOG FILE)

    Oracle 控制文件(CONTROLFILE)

    Oracle 归档日志

    Oracle (ROLLBACK)和撤(UNDO)

    Oracle 库实启动关闭过

    Oracle 10g SGA 的自化管理

    Oracle 例和Oracle(Oracle体系结构)

 

关闪回特性请参

    Oracle 回特性(FLASHBACK DATABASE)

    Oracle 回特性(FLASHBACK DROP & RECYCLEBIN)

    Oracle 回特性(Flashback Query、Flashback Table)

    Oracle 回特性(Flashback Version、Flashback Transaction)

 

基于用管理的备份备份请参

    Oracle 备份

    Oracle 热备份

    Oracle 备份复概

    Oracle 例恢

    Oracle 基于用管理恢(详细描述了介及其)

    SYSTEM 表空管理及备份

    SYSAUX表空管理及恢

 

RMAN备份复与管理请参

    RMAN 述及其体系结构

    RMAN 配置、管理

    RMAN 备份详

    RMAN

    RMAN catalog 建和使用

    基于catalog RMAN脚本

基于catalog 的RMAN 备份与

使用RMAN迁移文件系统数据库到ASM

    RMAN 备份困惑(使用plus archivelog)

 

ORACLE故障请参

    ORA-32004 错误处

    ORA-01658 错误

    CRS-0215 错误处

    ORA-00119,ORA-00132 错误处

    又一例SPFILE错误导无法启动

    对参数FAST_START_MTTR_TARGET = 0 解及

    SPFILE 错误导无法启动(ORA-01565)

 

ASM请参

    ASM例及ASM

    ASM 、目的管理

    使用 ASMCMD 工具管理ASM及文件

 

SQL/PLSQL请参

    SQLPlus 常用命令

    替代SQL*Plus

    使用Uniread实现SQLplus功能

    SQL -->SELECT 查询

    SQL --> NEW_VALUE 的使用

    SQL --> 集合(UNION UNION ALL)

    SQL --> 常用函

    SQL --> 视图(CREATE VIEW)

    SQL --> 建和管理表

    SQL --> 多表查询

    SQL --> 过滤和排序

    SQL --> 查询

    SQL --> 组与

    SQL --> 次化查询(START BY ... CONNECT BY PRIOR)

    SQL --> ROLLUPCUBE算符实现数汇总

    PL/SQL -->

    PL/SQL --> (Exception)

    PL/SQL --> 言基

    PL/SQL --> 流程控制

    PL/SQL --> PL/SQL记录

    PL/SQL --> 包的管理

    PL/SQL --> 式游(SQL%FOUND)

    PL/SQL --> 包重、初始化

    PL/SQL --> DBMS_DDL包的使用

    PL/SQL --> DML 触发

    PL/SQL --> INSTEAD OF 触发

    PL/SQL --> 储过

    PL/SQL -->

    PL/SQL --> 动态SQL

    PL/SQL --> 动态SQL的常见错误

 

ORACLE特性

    Oracle 常用目录结构(10g)

    使用OEM,SQL*Plus,iSQL*Plus 管理Oracle

    日志记录模式(LOGGING 、FORCE LOGGING 、NOLOGGING)

    表段、索引段上的LOGGINGNOLOGGING

    Oralce OMF 功能

    Oracle 限、系统权  

    Oracle 角色、配置文件

    Oracle

    Oracle 外部表

    使用外部表管理Oracle 告警日志(ALAERT_$SID.LOG)

    簇表及簇表管理(Index clustered tables)

    EXPDP 出工具的使用

    IMPDP 入工具的使用

    Oracle

    SQL*Loader使用方法

    用用户进程跟踪

    配置非默端口的动态

    配置ORACLE 接到

    system sys,sysoper sysdba 区别

    ORACLE_SID、DB_NAME、INSTANCE_NAME、DB_DOMIAN、GLOBAL_NAME

    Oracle 丁全集 (Oracle 9i 10g 11g Path)

    Oracle 10.2.0.1 10.2.0.4

Oracle kill session

手动删除oracle数据库

目录
相关文章
|
1月前
|
Oracle Cloud Native 关系型数据库
Oracle Linux 9.5 正式版发布 - Oracle 提供支持 RHEL 兼容发行版
Oracle Linux 9.5 正式版发布 - Oracle 提供支持 RHEL 兼容发行版
64 10
Oracle Linux 9.5 正式版发布 - Oracle 提供支持 RHEL 兼容发行版
|
27天前
|
缓存 并行计算 Linux
深入解析Linux操作系统的内核优化策略
本文旨在探讨Linux操作系统内核的优化策略,包括内核参数调整、内存管理、CPU调度以及文件系统性能提升等方面。通过对这些关键领域的分析,我们可以理解如何有效地提高Linux系统的性能和稳定性,从而为用户提供更加流畅和高效的计算体验。
30 2
|
27天前
|
缓存 网络协议 Linux
深入探索Linux操作系统的内核优化策略####
本文旨在探讨Linux操作系统内核的优化方法,通过分析当前主流的几种内核优化技术,结合具体案例,阐述如何有效提升系统性能与稳定性。文章首先概述了Linux内核的基本结构,随后详细解析了内核优化的必要性及常用手段,包括编译优化、内核参数调整、内存管理优化等,最后通过实例展示了这些优化技巧在实际场景中的应用效果,为读者提供了一套实用的Linux内核优化指南。 ####
45 1
|
1月前
|
机器学习/深度学习 负载均衡 算法
深入探索Linux内核调度机制的优化策略###
本文旨在为读者揭开Linux操作系统中至关重要的一环——CPU调度机制的神秘面纱。通过深入浅出地解析其工作原理,并探讨一系列创新优化策略,本文不仅增强了技术爱好者的理论知识,更为系统管理员和软件开发者提供了实用的性能调优指南,旨在促进系统的高效运行与资源利用最大化。 ###
|
1月前
|
监控 Oracle 关系型数据库
Linux平台Oracle开机自启动设置
【11月更文挑战第8天】在 Linux 平台设置 Oracle 开机自启动有多种方法,本文以 CentOS 为例,介绍了两种常见方法:使用 `rc.local` 文件(较简单但不推荐用于生产环境)和使用 `systemd` 服务(推荐)。具体步骤包括编写启动脚本、赋予执行权限、配置 `rc.local` 或创建 `systemd` 服务单元文件,并设置开机自启动。通过 `systemd` 方式可以更好地与系统启动过程集成,更规范和可靠。
117 2
|
1月前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
108 3
|
1月前
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
47 3
|
1月前
|
监控 网络协议 算法
Linux内核优化:提升系统性能与稳定性的策略####
本文深入探讨了Linux操作系统内核的优化策略,旨在通过一系列技术手段和最佳实践,显著提升系统的性能、响应速度及稳定性。文章首先概述了Linux内核的核心组件及其在系统中的作用,随后详细阐述了内存管理、进程调度、文件系统优化、网络栈调整及并发控制等关键领域的优化方法。通过实际案例分析,展示了这些优化措施如何有效减少延迟、提高吞吐量,并增强系统的整体健壮性。最终,文章强调了持续监控、定期更新及合理配置对于维持Linux系统长期高效运行的重要性。 ####
|
1月前
|
Oracle Ubuntu 关系型数据库
Linux平台Oracle开机自启动设置
【11月更文挑战第7天】本文介绍了 Linux 系统中服务管理机制,并详细说明了如何在使用 systemd 和 System V 的系统上设置 Oracle 数据库的开机自启动。包括创建服务单元文件、编辑启动脚本、设置开机自启动和启动服务的具体步骤。最后建议重启系统验证设置是否成功。
|
1月前
|
安全 网络协议 Linux
Linux操作系统的内核升级与优化策略####
【10月更文挑战第29天】 本文深入探讨了Linux操作系统内核升级的重要性,并详细阐述了一系列优化策略,旨在帮助系统管理员和高级用户提升系统的稳定性、安全性和性能。通过实际案例分析,我们展示了如何安全有效地进行内核升级,以及如何利用调优技术充分发挥Linux系统的潜力。 ####
64 1