溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

linux下實現mysql自動備份的腳本

發布時間:2021-08-31 10:19:12 來源:億速云 閱讀:193 作者:chen 欄目:數據庫

這篇文章主要介紹“linux下實現mysql自動備份的腳本”,在日常操作中,相信很多人在linux下實現mysql自動備份的腳本問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”linux下實現mysql自動備份的腳本”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

    腳本放在 /home/user/_backup.sh

    crontab

    # crontab -l

    # m h  dom mon dow   command

    28 16 * * * /home/user/mysql_backup.sh

    腳本如下

    #!/bin/sh
    # mysql_backup.sh: backup mysql databases and keep newest 5 days backup.
    #
    # Last updated: 20 March 2006
    # ----------------------------------------------------------------------
    # This is a free shell script under GNU GPL version 2.0 or above
    # Copyright (C) 2006 Sam Tang
    # Feedback/comment/suggestions : http://www.real-blog.com/
    # ----------------------------------------------------------------------
    # your mysql login information
    # db_user is mysql username
    # db_passwd is mysql password
    # db_host is mysql host
    # -----------------------------
    db_user="root"
    db_passwd="password"
    db_host="localhost"
    # the directory for story your backup file.
    backup_dir="/home/mybackup"
    # date format for backup file (dd-mm-yyyy)
    time="$(date +"%d-%m-%Y")"
    # mysql, mysqldump and some other bins path
    MYSQL="/usr/local/mysql/bin/mysql"
    MYSQLDUMP="/usr/local/mysql/bin/mysqldump"
    MKDIR="/bin/mkdir"
    RM="/bin/rm"
    MV="/bin/mv"
    GZIP="/bin/gzip"
    # check the directory for store backup is writeable
    test ! -w $backup_dir && echo "Error: $backup_dir is un-writeable." && exit 0
    # the directory for story the newest backup
    test ! -d "$backup_dir/backup.0/" && $MKDIR "$backup_dir/backup.0/"
    # get all databases
    all_db="$($MYSQL -u $db_user -h $db_host -p$db_passwd -Bse show databases)"
    for db in $all_db
    do
    $MYSQLDUMP -u $db_user -h $db_host -p$db_passwd $db | $GZIP -9 > "$backup_dir/backup.0/$time.$db.gz"
    done
    # delete the oldest backup
    test -d "$backup_dir/backup.5/" && $RM -rf "$backup_dir/backup.5"
    # rotate backup directory
    for int in 4 3 2 1 0
    do
    if(test -d "$backup_dir"/backup."$int")
    then
    next_int=`expr $int + 1`
    $MV "$backup_dir"/backup."$int" "$backup_dir"/backup."$next_int"
    fi
    done
    exit 0;

    備注:

    mysql是以mysql用戶身份運行的,對/home /mybackup不可寫也會失敗

    chmod 777 /home/mybackup問題解決了

到此,關于“linux下實現mysql自動備份的腳本”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女