データベースのバックアップ用Linuxシェルスクリプト

データベースのバックアップのためのスクリプトをいろいろ試したが、うまくいかなかった。1時間ごとにデータベースをバックアップしたいのですが。
quot;/etc/cron.hourly/"フォルダにファイルを追加し、chmodを755に変更したが、実行されない。 とりあえず擬似コードを書いてみた。

この操作のためのスクリプトを作成し、さらに何をすべきかを教えていただけると幸いです。 このスクリプトを /etc/cron.hourly/ フォルダに追加すると、次のようになります。

  • 現在の日付を取得し、変数 date=date(d_m_y_H_M_S) を作成する。
  • ファイル名の変数を作成する、filename="$date".gz
  • 以下のようにデータベースのダンプを取得する mysqldump --user=my_user --password=my_pass --default-character-set=utf8 my_database | gzip > "/var/www/vhosts/system/example.com/httpdocs/backups/$("filename"))
  • フォルダ /var/www/vhosts/system/example.com/httpdocs/backups/ 内の8日以上前のファイルをすべて削除する。
  • ファイル "/var/www/vhosts/system/example.com/httpdocs/backup_log.txt" に、次のテキストが書き込まれます:バックアップは $("date")` に作成されます。
  • ファイルの所有者をrootから"my_user"に変更する(chown)。なぜなら、"my_user"のFTPアカウントからバックアップファイルとログファイルを開きたいからです。
  • クーロンが終わるたびにメールが来るのは勘弁してほしい。>/dev/null 2>&1 が追加されます。
ソリューション

何時間も何時間もかけて、私は下のような解決策を作りました。他の方々のために、コピーペーストします。

まず、スクリプトファイルを作成し、このファイルに実行可能なパーミッションを与えます。

# cd /etc/cron.daily/
# touch /etc/cron.daily/dbbackup-daily.sh
# chmod 755 /etc/cron.daily/dbbackup-daily.sh
# vi /etc/cron.daily/dbbackup-daily.sh

次に、次の行をShift+Insでファイルにコピーします。

#!/bin/sh
now="$(date +'%d_%m_%Y_%H_%M_%S')"
filename="db_backup_$now".gz
backupfolder="/var/www/vhosts/example.com/httpdocs/backups"
fullpathbackupfile="$backupfolder/$filename"
logfile="$backupfolder/"backup_log_"$(date +'%Y_%m')".txt
echo "mysqldump started at $(date +'%d-%m-%Y %H:%M:%S')" >> "$logfile"
mysqldump --user=mydbuser --password=mypass --default-character-set=utf8 mydatabase | gzip > "$fullpathbackupfile"
echo "mysqldump finished at $(date +'%d-%m-%Y %H:%M:%S')" >> "$logfile"
chown myuser "$fullpathbackupfile"
chown myuser "$logfile"
echo "file permission changed" >> "$logfile"
find "$backupfolder" -name db_backup_* -mtime +8 -exec rm {} \;
echo "old files deleted" >> "$logfile"
echo "operation finished at $(date +'%d-%m-%Y %H:%M:%S')" >> "$logfile"
echo "*****************" >> "$logfile"
exit 0

編集してください: InnoDBを使用していて、バックアップに時間がかかる場合は、ロックを防ぐために "single-transaction" 引数を追加することができます。そのため、mysqldumpの行は次のようになります:

mysqldump --user=mydbuser --password=mypass --default-character-set=utf8
          --single-transaction mydatabase | gzip > "$fullpathbackupfile"
解説 (8)

このようなスクリプトを作成します:

#!/bin/sh -e

location=~/`date +%Y%m%d_%H%M%S`.db

mysqldump -u root --password= database_name > $location

gzip $location

次に、このスクリプトを実行するユーザーの crontab を編集します:

$> crontab -e

というエントリーを追加します。

01 * * * * ~/script_path.sh

これで、毎日毎時1分に実行されるようになります。

あとは、ロールケーキなどの機能を追加すればOKです。

解説 (3)

同じ問題が発生しました。 しかし、なんとかスクリプトを書きました。 これが役立つことを願っています。

#!/bin/bash
# Database credentials
user="username"
password="password"
host="localhost"
db_name="dbname"
# Other options
backup_path="/DB/DB_Backup"
date=$(date +"%d-%b-%Y")
# Set default file permissions
umask 177
# Dump database into SQL file
mysqldump --user=$user --password=$password --host=$host $db_name >$backup_path/$db_name-$date.sql

# Delete files older than 30 days
find $backup_path/* -mtime +30 -exec rm {} \;

#DB backup log
echo -e "$(date +'%d-%b-%y  %r '):ALERT:Database has been Backuped"    >>/var/log/DB_Backup.log
解説 (0)
#!/bin/sh
#Procedures = For DB Backup
#Scheduled at : Every Day 22:00

v_path=/etc/database_jobs/db_backup
logfile_path=/etc/database_jobs
v_file_name=DB_Production
v_cnt=0

MAILTO="abc@as.in"
touch "$logfile_path/kaka_db_log.log"

#DB Backup
mysqldump -uusername -ppassword -h111.111.111.111 ddbname > $v_path/$v_file_name`date +%Y-%m-%d`.sql 
if [ "$?" -eq 0 ]
  then
   v_cnt=`expr $v_cnt + 1`
  mail -s "DB Backup has been done successfully" $MAILTO < $logfile_path/db_log.log
 else
   mail -s "Alert : kaka DB Backup has been failed" $MAILTO < $logfile_path/db_log.log
   exit
fi
解説 (0)

これが誰かを助ける場合に備えて、ubuntu用のmysqlバックアップスクリプトを次に示します。

#Mysql back up script

start_time="$(date -u +%s)"

now(){
date +%d-%B-%Y_%H-%M-%S
}

ip(){
/sbin/ifconfig eth0 2>/dev/null|awk '/inet addr:/ {print $2}'|sed 's/addr://'
}

filename="`now`".zip
backupfolder=/path/to/any/folder
fullpathbackupfile=$backupfolder/$filename
db_user=xxx
db_password=xxx
db_name=xxx

printf "\n\n"
printf "******************************\n"
printf "Started Automatic Mysql Backup\n"
printf "******************************\n"
printf "TIME: `now`\n"
printf "IP_ADDRESS: `ip` \n"
printf "DB_SERVER_NAME: DB-SERVER-1\n"

printf "%sBACKUP_FILE_PATH $fullpathbackupfile\n"

printf "Starting Mysql Dump \n"

mysqldump -u $db_user -p$db_password $db_name| pv | zip > $fullpathbackupfile

end_time="$(date -u +%s)"

elapsed=$(($end_time-$start_time))

printf "%sMysql Dump Completed In $elapsed seconds\n"

printf "******************************\n"

PS:ubuntuにpvとzipをインストールすることを忘れないでください。

sudo apt install pv
sudo apt install zip

6時間ごとに実行するためにubuntuで crontab -eを使用してcrontabを設定する方法は次のとおりです。

0 */6 * * * sh /path/to/shfile/backup-mysql.sh >> /path/to/logs/backup-mysql.log 2>&1

すばらしいのは、どこからでも解凍しやすいzipファイルを作成することです。

解説 (0)
#!/bin/bash

# Add your backup dir location, password, mysql location and mysqldump        location
DATE=$(date +%d-%m-%Y)
BACKUP_DIR="/var/www/back"
MYSQL_USER="root"
MYSQL_PASSWORD=""
MYSQL='/usr/bin/mysql'
MYSQLDUMP='/usr/bin/mysqldump'
DB='demo'

#to empty the backup directory and delete all previous backups
rm -r $BACKUP_DIR/*  

mysqldump -u root -p'' demo | gzip -9 > $BACKUP_DIR/demo$date_format.sql.$DATE.gz

#changing permissions of directory 
chmod -R 777 $BACKUP_DIR
解説 (0)

このオープンソースツール、matiri、https://github.com/AAFC-MBB/matiriを検討してください。これは、Sqlite3のメタデータを含む同時mysqlバックアップスクリプトです。 特徴:

マルチサーバー:複数のMySQLサーバーは、同じまたは個別の物理サーバーに同じ場所に配置されているかどうかに関係なくサポートされます。 並列:バックアップするサーバー上の各データベースは、並列に別々に行われます(通貨設定可能:デフォルト:3)。 圧縮:各データベースバックアップが圧縮されています。 チェックサム:保存されている各圧縮バックアップファイルのSHA256とすべてのファイルのアーカイブ。 アーカイブ済み:すべてのデータベースバックアップが一緒になって単一のファイルになりました。 記録:Sqlite3データベースに保存されているバックアップ情報。

完全な開示:元のマティリ作者。

解説 (0)

DBAとして、問題が発生した場合にMySQLデータベースのバックアップをスケジュールして、現在のバックアップからデータベースを回復できるようにする必要があります。

ここでは、mysqldumpを使用してmysqlデータベースのバックアップを取得しています。これは、スクリプトに入れることができるのと同じです。

[orahow@oradbdb DB_Backup] $ cat .backup_script.sh。

#!/bin/bash
# Database credentials
user="root"
password="1Loginxx"
db_name="orahowdb"
v_cnt=0
logfile_path=/DB_Backup
touch "$logfile_path/orahowdb_backup.log"
# Other options
backup_path="/DB_Backup"
date=$(date +"%d-%b-%Y-%H-%M-%p")
# Set default file permissions

読み続けます。 .... MySQLバックアップ

解説 (0)

MYSQLデータベースのバックアップを作成するために、シェルスクリプトを準備しました。 データベースのバックアップを作成するために使用できます。

    #!/bin/bash
    export PATH=/bin:/usr/bin:/usr/local/bin
    TODAY=`date +"%d%b%Y_%I:%M:%S%p"`

    ################################################################
    ################## Update below values  ########################
    DB_BACKUP_PATH='/backup/dbbackup'
    MYSQL_HOST='localhost'
    MYSQL_PORT='3306'
    MYSQL_USER='auriga'
    MYSQL_PASSWORD='auriga@123'
    DATABASE_NAME=( Project_O2 o2)
    BACKUP_RETAIN_DAYS=30   ## Number of days to keep local backup copy; Enable script code in end of th script

    #################################################################
    { mkdir -p ${DB_BACKUP_PATH}/${TODAY}
        echo "
                                ${TODAY}" >> ${DB_BACKUP_PATH}/Backup-Report.txt
    } || {
        echo "Can not make Directry"
        echo "Possibly Path is wrong"
    }
    { if ! mysql -u ${MYSQL_USER} -p${MYSQL_PASSWORD} -e 'exit'; then
        echo 'Failed! You may have Incorrect PASSWORD/USER ' >> ${DB_BACKUP_PATH}/Backup-Report.txt
        exit 1
    fi

        for DB in "${DATABASE_NAME[@]}"; do
            if ! mysql -u ${MYSQL_USER} -p${MYSQL_PASSWORD} -e "use "${DB}; then
                echo "Failed! Database ${DB} Not Found on ${TODAY}" >> ${DB_BACKUP_PATH}/Backup-Report.txt

            else
                # echo "Backup started for database - ${DB}"            
                # mysqldump -h localhost -P 3306 -u auriga -pauriga@123 Project_O2      # use gzip..

                mysqldump -h ${MYSQL_HOST} -P ${MYSQL_PORT} -u ${MYSQL_USER} -p${MYSQL_PASSWORD} \
                          --databases ${DB} | gzip > ${DB_BACKUP_PATH}/${TODAY}/${DB}-${TODAY}.sql.gz

                if [ $? -eq 0 ]; then
                    touch ${DB_BACKUP_PATH}/Backup-Report.txt
                    echo "successfully backed-up of ${DB} on ${TODAY}" >> ${DB_BACKUP_PATH}/Backup-Report.txt
                    # echo "Database backup successfully completed"

                else
                    touch ${DB_BACKUP_PATH}/Backup-Report.txt
                    echo "Failed to backup of ${DB} on ${TODAY}" >> ${DB_BACKUP_PATH}/Backup-Report.txt
                    # echo "Error found during backup"
                    exit 1
                fi
            fi
        done
    } || {
        echo "Failed during backup"
        echo "Failed to backup on ${TODAY}" >> ${DB_BACKUP_PATH}/Backup-Report.txt
        # ./myshellsc.sh 2> ${DB_BACKUP_PATH}/Backup-Report.txt
    }

    ##### Remove backups older than {BACKUP_RETAIN_DAYS} days  #####

    # DBDELDATE=`date +"%d%b%Y" --date="${BACKUP_RETAIN_DAYS} days ago"`

    # if [ ! -z ${DB_BACKUP_PATH} ]; then
    #       cd ${DB_BACKUP_PATH}
    #       if [ ! -z ${DBDELDATE} ] && [ -d ${DBDELDATE} ]; then
    #             rm -rf ${DBDELDATE}
    #       fi
    # fi

    ### End of script ####

スクリプトでは、ユーザー名、パスワード、データベースの名前(または複数の場合はデータベース)と、異なる場合はポート番号を指定するだけです。

スクリプトを実行するには、コマンドを次のように使用します。

sudo ./script.sc

また、次のようなファイルで結果を表示する場合は、次のことをお勧めします。 失敗が発生するか、バックアップに成功します。 次に、コマンドを次のように使用します。

sudo ./myshellsc.sh 2>> Backup-Report.log

ありがとうございました。

解説 (0)