Heim Datenbank MySQL-Tutorial 中小型数据库备份恢复方案

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

Jun 07, 2016 pm 03:24 PM
oracle 备份 恢复 数据库 方案 进入

欢迎进入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] 

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

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

MySQL: Eine Einführung in die beliebteste Datenbank der Welt MySQL: Eine Einführung in die beliebteste Datenbank der Welt Apr 12, 2025 am 12:18 AM

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

So verschlüsseln Sie die Oracle -Ansicht So verschlüsseln Sie die Oracle -Ansicht Apr 11, 2025 pm 08:30 PM

Mit der Verschlüsselung von Oracle View können Sie Daten in der Ansicht verschlüsseln und so die Sicherheit sensibler Informationen verbessern. Die Schritte umfassen: 1) Erstellen des Master -Verschlüsselungsschlüssels (MEK); 2) Erstellen einer verschlüsselten Ansicht, der Ansicht und der Verschlüsselung der Ansicht und der MEK angeben; 3) Benutzern Sie die Benutzer, auf die verschlüsselte Ansicht zuzugreifen. Wie verschlüsselte Ansichten funktionieren: Wenn ein Benutzer nach einer verschlüsselten Ansicht nachgefragt wird, verwendet Oracle MEK, um Daten zu entschlüsseln und sicherzustellen, dass nur autorisierte Benutzer auf lesbare Daten zugreifen können.

Warum MySQL verwenden? Vorteile und Vorteile Warum MySQL verwenden? Vorteile und Vorteile Apr 12, 2025 am 12:17 AM

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

Wie man die Oracle -Installation deinstalliert Wie man die Oracle -Installation deinstalliert Apr 11, 2025 pm 08:24 PM

Deinstallieren Sie die Methode für Oracle -Installationsfehler: Schließen Sie den Oracle -Service, löschen Sie Oracle -Programmdateien und Registrierungsschlüssel, Deinstallieren Sie Oracle -Umgebungsvariablen und starten Sie den Computer neu. Wenn das Deinstall fehlschlägt, können Sie das Oracle Universal Deinstall -Tool manuell deinstallieren.

So erstellen Sie Oracle Dynamic SQL So erstellen Sie Oracle Dynamic SQL Apr 12, 2025 am 06:06 AM

SQL -Anweisungen können basierend auf der Laufzeiteingabe erstellt und ausgeführt werden, indem die dynamische SQL von Oracle verwendet wird. Zu den Schritten gehören: Vorbereitung einer leeren Zeichenfolgenvariable zum Speichern von dynamisch generierten SQL -Anweisungen. Verwenden Sie die sofortige Ausführung oder Vorbereitung, um dynamische SQL -Anweisungen zu kompilieren und auszuführen. Verwenden Sie die Bind -Variable, um die Benutzereingabe oder andere dynamische Werte an dynamische SQL zu übergeben. Verwenden Sie sofortige Ausführung oder führen Sie aus, um dynamische SQL -Anweisungen auszuführen.

So erstellen Sie Cursor in Oracle Loop So erstellen Sie Cursor in Oracle Loop Apr 12, 2025 am 06:18 AM

In Oracle kann die For -Loop -Schleife Cursors dynamisch erzeugen. Die Schritte sind: 1. Definieren Sie den Cursortyp; 2. Erstellen Sie die Schleife; 3.. Erstellen Sie den Cursor dynamisch; 4. Führen Sie den Cursor aus; 5. Schließen Sie den Cursor. Beispiel: Ein Cursor kann mit dem Zyklus für Kreislauf erstellt werden, um die Namen und Gehälter der Top 10 Mitarbeiter anzuzeigen.

So öffnen Sie eine Datenbank in Oracle So öffnen Sie eine Datenbank in Oracle Apr 11, 2025 pm 10:51 PM

Die Schritte zum Öffnen einer Oracle -Datenbank sind wie folgt: Öffnen Sie den Oracle -Datenbank -Client und stellen Sie eine Verbindung zum Datenbankserver her: Verbinden Sie Benutzername/Passwort@sservername Verwenden Sie den Befehl SQLPLUS, um die Datenbank zu öffnen: SQLPLUS

So überprüfen Sie ungültige Nummern von Oracle So überprüfen Sie ungültige Nummern von Oracle Apr 11, 2025 pm 08:27 PM

Oracle Ungültige numerische Fehler können durch Fehlpaarung des Datentyps, numerische Überlauf, Datenkonvertierungsfehler oder Datenbeschäftigung verursacht werden. Zu den Schritten zur Fehlerbehebung gehören das Überprüfen von Datentypen, das Erkennen digitaler Überläufe, das Überprüfen von Datenkonvertierungen, das Überprüfen der Datenbeschädigung und das Erforschen anderer möglicher Lösungen wie das Konfigurieren des Parameters nls_numeric_characters und das Aktivieren der Datenüberprüfungs -Protokollierung.

See all articles