Oracle 自动化备份脚本
admin
2023-04-16 06:02:04
0

Oracle 日常RMAN备份脚本,很基础。但是对于多个需要备份的Oracle数据库,可以很简单实施,并利于后期批量状态的查询。

  1. 备份脚本,基于linux,windows环境需要适当修改。
    主脚本,会调用2,3步骤的rman.sql&status.sql

    $ more main.sh
    #set env
    #########################Change the below parameter for the different server##################
    export host_ip=172.16.32.115
    export instance_name=liang
    export username=liang
    export password=liang
    export syspsw=oracle
    export backup_home=/home/oracle/bk
    export ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_1
    export PATH=$PATH:$ORACLE_HOME/db_1/bin:/sbin:/usr/sbin
    #####################################################################################
    export curTime=$(date "+%Y%m%d")
    mkdir $backup_home/ftp/$curTime
    echo "-----------------------------RMAN start-----------------------------";date
    #backup start
    cd $backup_home
    $ORACLE_HOME/bin/rman target sys/$syspsw@$host_ip:1521/$instance_name cmdfile='rman.sql'
    echo "------------------------------RMAN End------------------------------";date
    sleep 10
    echo "------------------------------SQL Start------------------------------";date
    $ORACLE_HOME/bin/sqlplus $username/$password@$host_ip:1521/$instance_name @status.sql
    echo "------------------------------END-----------------------------";date
  2. RMAN备份sql脚本

    [oracle@test bk]$ more rman.sql
    run
    {
    ALLOCATE CHANNEL node_c1 DEVICE TYPE DISK MAXPIECESIZE=5G;
    ALLOCATE CHANNEL node_c2 DEVICE TYPE DISK MAXPIECESIZE=5G;
    backup as compressed backupset database format 'C:\ftp\uploadfile\db_%U.bak_%T';
    sql 'alter system switch logfile';
    CROSSCHECK ARCHIVELOG ALL;
    backup as compressed backupset archivelog all format 'C:\ftp\uploadfile\archivelog_%d_%s_%p_%T' not backed up 2 times;
    backup spfile format 'C:\ftp\uploadfile\spfile_%U_%T';
    backup current controlfile format 'C:\ftp\uploadfile\controlfile_%d_%s_%p_%I_%u_%T';
    sql 'alter system switch logfile';
    CROSSCHECK BACKUP;
    CROSSCHECK COPY;
    delete noprompt archivelog all completed before 'sysdate-7';
    release channel node_c1;
    release channel node_c2;
    }
  3. 查询备份状态的脚本,并将查询信息打印到日志,方便查询。
    $ more status.sql
    ----每日归档产生量,可以判断数据库是否繁忙
    spool $backup_home/redo_switch.log;
    set echo off
    set feedback off
    set colsep ','
    set pagesize 2000
    set term off
    set heading off
    set line 400
    col Count for 9999
    col GB for 99999
    select
    d.dbid,
    to_char(trunc(completion_time),'yyyy-mm-dd') as "Date"
    ,count(*) as "Count"
    ,substr((sum(blocks*block_size))/1024/1024/1024,0,4) as "GB"
    from v$archived_log,v$database d
    group by trunc(completion_time),d.dbid;
    spool off;
    ---查询表空间使用率
    spool $backup_home/tablepace_usage.log;
    set echo off
    set feedback off
    set colsep ','
    set pagesize 2000
    set term off
    set heading off
    set line 400
    col startup_time for a20
    col status for a6
    col tablespace_name for a20
    col total_mb for 99999999
    col used_mb for 99999999
    col used_pct for a10
    select
    d.dbid,
    to_char(b.STARTUP_TIME,'yyyy-mm-dd-hh34-mi-ss') as startup_time,
    b.status,
    total.tablespace_name,
    round(total.MB, 2) as Total_MB,
    round(total.MB - free.MB, 2) as Used_MB,
    round((1 - free.MB / total.MB) * 100, 2) || '%' as Used_Pct
    from (select tablespace_name, sum(bytes) / 1024 / 1024 as MB
    from dba_free_space
    group by tablespace_name) free,
    (select tablespace_name, sum(bytes) / 1024 / 1024 as MB
    from dba_data_files
    group by tablespace_name) total, v$instance b, v$database d
    where free.tablespace_name = total.tablespace_name;
    spool off;
    --- 查看近7天备份情况
    spool /home/oracle/bk/log/rman.log;
    set echo off
    set feedback off
    set colsep ','
    set pagesize 2000
    set term off
    set heading off
    set line 202000
    col DBID for 9999999999
    col status for a25
    col type for a12
    col  start_time for a22
    col  Finish_time for a22
    col in_sec for a12
    col out_sec for a12
    col command for a8
    col  INPUT_M for 99999
    col  OUTPUT_M for 99999
    col obj_type for a15
    select d.DBID as DBID,
    s.status as status,
    b.INPUT_TYPE as type,
    to_char(b.START_TIME,'yyyy-mm-dd hh34:mi:ss') as start_time,
    to_char(b.end_time, 'yyyy-mm-dd hh34:mi:ss') as  Finish_time,
    b.INPUT_BYTES_PER_SEC_DISPLAY in_sec,
    b.OUTPUT_BYTES_PER_SEC_DISPLAY out_sec,
    s.OPERATION as command,
    trunc(s.INPUT_BYTES/1024/1024,2) as INPUT_M,
    trunc(s.OUTPUT_BYTES/1024/1024,2) as OUTPUT_M,
    s.OBJECT_TYPE as obj_type
    from v$rman_status s,v$rman_backup_job_details b, v$database d
    where to_char(s.START_TIME, 'yyyy-mm-dd hh34:mi:ss') < to_char(sysdate,'yyyy-mm-dd hh34:mi:ss')
    and to_char(s.END_TIME, 'yyyy-mm-dd hh34:mi:ss') > to_char(sysdate-7,'yyyy-mm-dd hh34:mi:ss')
    and s.COMMAND_ID=b.COMMAND_ID
    order by s.START_TIME desc ;
    spool off;
    exit;

相关内容

热门资讯

美防长称美伊停火协议依然有效 △赫格塞思(资料图)当地时间5月12日,美国国防部长赫格塞思表示,他们针对伊朗问题的所有情况都制定了...
特朗普二度来华,五大博弈看点,... 就在5月11日,外交部官宣了一则重磅消息:应中国邀请,美国总统特朗普将于5月13日至15日开启访华行...
科学家预测:“哥斯拉级”厄尔尼... 科学家近日发出警告,太平洋上空正在形成一种被称为“哥斯拉”级的罕见厄尔尼诺气候模式。有科学家预测,这...
200亿美金估值的可灵,值母公... 文 | 影子备忘录 要说今年科技圈最火的赛道,AI短剧绝对排得上号。一部AI仿真人短剧,3人团队、...
多名中国公民在越南乘机遗失财物... 近日,多名中国公民反映在越乘机过程中财物遗失,中国驻胡志明市总领馆提醒中国公民注意:一、强化防范意识...
电视机尺寸一览表70寸长宽 电视机尺寸一览表70寸长宽:一般液晶电视显示屏都是16比9,70寸就是说客它对角线长70寸是106....
东莞一社区推出生育奖励方案,二... 极目新闻记者 柳之萌近日,广东东莞万江街道谷涌社区出台生育奖励方案,对符合条件的二孩家庭一次性奖励1...
80寸液晶电视尺寸长宽多少厘米 80寸液晶电视尺寸长宽多少厘米:80寸的液晶电视大概为181x111厘米,即长度大概在181厘米,宽...
石膏线一般用多久会掉 大家在装修客厅吊顶的时候,一般都会用石膏线来装。石膏线的施工非常方便,而且装修价格也比较便宜,所以很...
10公分石膏线下挂尺寸 10公分石膏线下挂,大概在8公分左右,这样排出来的石膏线才会比较好看,而且边缘也会比较整齐一些,如果...