Home Database Mysql Tutorial 中小型数据库备份恢复方案

中小型数据库备份恢复方案

Jun 07, 2016 pm 03:24 PM
oracle backup recover database plan Enter

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 4、创建RMAN备份shell脚本 [python] oracle@BKDB01p:/u02/database/common/rman_scripts more db_bak_rman_catalog.sh ##=========================================================== ## File nam

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入


    4、创建RMAN备份shell脚本
    [python]
    oracle@BKDB01p:/u02/database/common/rman_scripts> more db_bak_rman_catalog.sh
    ##===========================================================
    ##   File name: db_bak_rman_catalog.sh
    ##   Usage: db_bak_rman_catalog.sh
    ##   Desc:
    ##        The script uses to backup database with level 0.
    ##============================================================
    #!/bin/bash
    # User specific environment and startup programs
    if [ -f ~/.bash_profile ];
    then
    . ~/.bash_profile
    fi
    # --------------------------
    #   Check SID
    # --------------------------
    if [ -z "${1}" ];then
    echo "Usage: "
    echo "      `basename $0` ORACLE_SID"
    exit 1
    fi
    # -------------------------------
    #  Set environment here
    # -------------------------------
    ORACLE_SID=${1};                                    export ORACLE_SID
    TIMESTAMP=`date +%Y%m%d%H%M`;                       export TIMESTAMP
    LOG_DIR=/u02/database/${ORACLE_SID}/backup          export LOG_DIR
    RMAN_LOG=${LOG_DIR}/${ORACLE_SID}_bak_${TIMESTAMP}.log
    SSH_LOG=${LOG_DIR}/${ORACLE_SID}_bak_full_${TIMESTAMP}.log
    MAIL_DIR=/users/oracle/sendEmail-v1.56
    MAIL_FM=oracle@BKDB01p
    RETENTION=5
    echo "----------------------------------------------------------------" 》${SSH_LOG}
    echo "Step 1. Start rman to backup at `date`."                          》${SSH_LOG}
    echo "----------------------------------------------------------------" 》${SSH_LOG}
    $ORACLE_HOME/bin/rman log=${RMAN_LOG} 《EOF
    connect target sys/xxx@${ORACLE_SID}
    connect catalog rman_user/xxx@CATADB
    resync catalog;
    run {execute global script global_inc0;}
    exit;
    EOF
    RV=$?
    cat ${RMAN_LOG}》${SSH_LOG}
    echo ""        》${SSH_LOG}
    echo "=====>MSG1: RMAN backup end at `date`." 》${SSH_LOG}
    if [ $RV -ne "0" ]; then
    echo "" 》${SSH_LOG}
    echo "=====>MSG2: RMAN backup error at `date`." 》${SSH_LOG}
    $MAIL_DIR/sendEmail -f $MAIL_FM -u "Failed RMAN backup for $ORACLE_SID on `hostname`." -t dba@12306.com -o message-file=${SSH_LOG}
    exit
    else
    echo "" 》${SSH_LOG}
    echo "=====>MSG2: No error found during RMAN backup peroid at `date`" 》${SSH_LOG}
    rm -rf ${RMAN_LOG} 2>/dev/null
    fi
    echo "-------------------------------------------------------------------------" 》${SSH_LOG}
    echo "Step 2. Start ftp backupset to backup server at `date`."                   》${SSH_LOG}
    echo "-------------------------------------------------------------------------" 》${SSH_LOG}
    SRC_DB_BAK_DIR=/u02/database/${ORACLE_SID}/flash_recovery_area/${ORACLE_SID}
    SRC_ADD=10.1.2.101
    TARG_DB_BAK_DIR=/u02/database/${ORACLE_SID}/flash_recovery_area
    RSYN_LOG=${LOG_DIR}/rsync_${TIMESTAMP}.log
    # rsync is used to ftp backup set to bak server.
    rsync -avzSH --progress --delete-after oracle@${SRC_ADD}:${SRC_DB_BAK_DIR} ${TARG_DB_BAK_DIR} >${RSYN_LOG} 2>&1
    RV=$?
    cat ${RSYN_LOG}》${SSH_LOG}
    if [ $RV -ne "0" ]; then
    echo ""                                                    》${SSH_LOG}
    echo "=====>MSG3: FTP backupset error at `date`."          》${SSH_LOG}
    MAIL_SUB="Failed archive log sync for $ORACLE_SID on `hostname` at `date`."
    $MAIL_DIR/sendEmail -f $MAIL_FM -u $MAIL_SUB -t dba@12306.com -o message-file=${SSH_LOG}
    exit
    else
    echo ""                                                 》${SSH_LOG}
    echo -e "=====>MSG3: No error found during FTP peroid." 》${SSH_LOG}
    rm -rf $FTP_LOG 2>/dev/null
    fi
    echo "-------------------------------------------------------------------------"  》${SSH_LOG}
    echo "Step 3. RMAN backup and ftp backupset finished at `date`."                  》${SSH_LOG}
    echo "-------------------------------------------------------------------------"  》${SSH_LOG}
    MAIL_SUB="Sucessful completed for ${ORACLE_SID} RMAN backup and ftp backupset at `date`."
    $MAIL_DIR/sendEmail -f $MAIL_FM -u $MAIL_SUB -t dba@12306.com -o message-file=${SSH_LOG}
    # ------------------------------------------------
    # Removing files older than $RETENTION parameter
    # ------------------------------------------------
    find ${LOG_DIR} -name "*.*" -mtime +$RETENTION -exec rm {} \;
    exit
    5、自动FTP archivelog脚本
    [python]
    oracle@BKDB01p:/u02/database/common/rman_scripts> more autoftp_arch.sh
    #!/bin/bash
    ORACLE_SID=${1};                        export ORACLE_SID
    TIMESTAMP=`date +%Y%m%d%H%M`;           export TIMESTAMP
    LOG_DIR=/u02/database/${ORACLE_SID}/backup
    #Define FTP variable
    SRC_DB_BAK_DIR=/u02/database/${ORACLE_SID}/archive
    SRC_ADD=10.1.2.101
    TARG_DB_BAK_DIR=/u02/database/${ORACLE_SID}
    RSYN_LOG=${LOG_DIR}/rsync_arc_${TIMESTAMP}.log
    RSYN_ERR_LOG=${LOG_DIR}/rsync_arc_${TIMESTAMP}_err.log
    rsync -avzSH --progress --delete-after oracle@${SRC_ADD}:${SRC_DB_BAK_DIR} ${TARG_DB_BAK_DIR} >${RSYN_LOG} 2>${RSYN_ERR_LOG}
    RV=$?
    if [ ! -s ${RSYN_ERR_LOG} ];then
    rm -rf ${RSYN_ERR_LOG} 2>/dev/null
    else
    mail -s "Failed FTP archive log for $ORACLE_SID on `hostname`" dba@12306.com     fi
    exit
    6、部署备份脚本到crontab
    如果你的数据库比较少,则直接将上面的备份脚本与自动FTP archivelog脚本部署到crontab.
    如果你的数据库比较多,建议将上面的脚本封装到另外的一个文件,然后部署到crontab.
    如下面的full_bak_by_rman.sh实际上是包含了多个db_bak_rman_catalog.sh ,后面的多个full开头的使用类是的原理。
    #Rman backup and restore database
    0 1 * * 1-6 /u02/database/common/rman_scripts/full_bak_by_rman.sh
    0 3 * * 1-6 /u02/database/common/rman_scripts/full_resotre_by_rman.sh  #这个是用来还原的脚本
    #Auto ftp archive log from prod to bak server
    */16 7-20 * *  1-6 /u02/database/common/rman_scripts/full_autoftp_arch.sh

  [1] [2] 

中小型数据库备份恢复方案

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat Commands and How to Use Them
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

MySQL: An Introduction to the World's Most Popular Database MySQL: An Introduction to the World's Most Popular Database Apr 12, 2025 am 12:18 AM

MySQL is an open source relational database management system, mainly used to store and retrieve data quickly and reliably. Its working principle includes client requests, query resolution, execution of queries and return results. Examples of usage include creating tables, inserting and querying data, and advanced features such as JOIN operations. Common errors involve SQL syntax, data types, and permissions, and optimization suggestions include the use of indexes, optimized queries, and partitioning of tables.

Why Use MySQL? Benefits and Advantages Why Use MySQL? Benefits and Advantages Apr 12, 2025 am 12:17 AM

MySQL is chosen for its performance, reliability, ease of use, and community support. 1.MySQL provides efficient data storage and retrieval functions, supporting multiple data types and advanced query operations. 2. Adopt client-server architecture and multiple storage engines to support transaction and query optimization. 3. Easy to use, supports a variety of operating systems and programming languages. 4. Have strong community support and provide rich resources and solutions.

How to encrypt oracle view How to encrypt oracle view Apr 11, 2025 pm 08:30 PM

Oracle View Encryption allows you to encrypt data in the view, thereby enhancing the security of sensitive information. The steps include: 1) creating the master encryption key (MEk); 2) creating an encrypted view, specifying the view and MEk to be encrypted; 3) authorizing users to access the encrypted view. How encrypted views work: When a user querys for an encrypted view, Oracle uses MEk to decrypt data, ensuring that only authorized users can access readable data.

How to uninstall Oracle installation failed How to uninstall Oracle installation failed Apr 11, 2025 pm 08:24 PM

Uninstall method for Oracle installation failure: Close Oracle service, delete Oracle program files and registry keys, uninstall Oracle environment variables, and restart the computer. If the uninstall fails, you can uninstall manually using the Oracle Universal Uninstall Tool.

How to create oracle dynamic sql How to create oracle dynamic sql Apr 12, 2025 am 06:06 AM

SQL statements can be created and executed based on runtime input by using Oracle's dynamic SQL. The steps include: preparing an empty string variable to store dynamically generated SQL statements. Use the EXECUTE IMMEDIATE or PREPARE statement to compile and execute dynamic SQL statements. Use bind variable to pass user input or other dynamic values ​​to dynamic SQL. Use EXECUTE IMMEDIATE or EXECUTE to execute dynamic SQL statements.

How to read the oracle awr report How to read the oracle awr report Apr 11, 2025 pm 09:45 PM

An AWR report is a report that displays database performance and activity snapshots. The interpretation steps include: identifying the date and time of the activity snapshot. View an overview of activities and resource consumption. Analyze session activities to find session types, resource consumption, and waiting events. Find potential performance bottlenecks such as slow SQL statements, resource contention, and I/O issues. View waiting events, identify and resolve them for performance. Analyze latch and memory usage patterns to identify memory issues that are causing performance issues.

How to use triggers for oracle How to use triggers for oracle Apr 11, 2025 pm 11:57 PM

Triggers in Oracle are stored procedures used to automatically perform operations after a specific event (insert, update, or delete). They are used in a variety of scenarios, including data verification, auditing, and data maintenance. When creating a trigger, you need to specify the trigger name, association table, trigger event, and trigger time. There are two types of triggers: the BEFORE trigger is fired before the operation, and the AFTER trigger is fired after the operation. For example, the BEFORE INSERT trigger ensures that the age column of the inserted row is not negative.

How to create cursors in oracle loop How to create cursors in oracle loop Apr 12, 2025 am 06:18 AM

In Oracle, the FOR LOOP loop can create cursors dynamically. The steps are: 1. Define the cursor type; 2. Create the loop; 3. Create the cursor dynamically; 4. Execute the cursor; 5. Close the cursor. Example: A cursor can be created cycle-by-circuit to display the names and salaries of the top 10 employees.

See all articles