リモートmysqlからの自動バックアップ

リモートmysqlからの自動バックアップ

私はオンラインウェブサイトのコンテンツを保存するmysqlデータベースを毎日バックアップしており、この6つのコマンドを1つに自動化したいと思います。

私は簡単な解決策を試しました。コマンドのリストをBashスクリプトに入れるだけです。スクリプトがリモートホストに入ると停止するため失敗します。

助けてくれてありがとう。

私の失敗した(bashスクリプト)試みは次のとおりです。

#! /bin/bash

  echo "Connecting to the remote host ...";
  ssh -p myport [email protected] ;
  echo "Making the backup on the remote host ...";
  mysqldump --databases --user=mysqluser --password=mypassword mydatabase > backup_copy.sql ;
  echo "Compressing the sql backup ...";
  gzip backup_copy.sql;
  echo "Leaving the remote host ...";
  exit;
  echo "Copying the backup from the remote host ...";
  scp -P myport [email protected]:backup_copy.sql.gz /my/location/to/store/backups ;
  echo "Task finished";

ベストアンサー1

#!/bin/bash

# database credentials
DATABASEHOST="host"
DATABASEUSER="user"
DATABASEPASSWORD="password"
DATABASESCHEMA="database"
DATABASEENV="backup"

# Local directory of mysqldump file
LOCALDIR=/home/user/db-bkp

# Temporary directory for compressed file
TEMPDIR=/home/user/tmp

# Remote Directory for backups.
REMOTEDIR=/home/user/db-bkp

# Backup host to login to
BACKUPHOST="otherhost"
#--- end config

echo $(date +%H:%M)
echo "Creating the MySQL dump" 
mysqldump --host="$DATABASEHOST" --user="$DATABASEUSER" --password="$DATABASEPASSWORD" --single-transaction "$DATABASESCHEMA" > "$LOCALDIR"/"$(date +%Y%m%d)_bkp_$DATABASESCHEMA.sql"

#echo "Generating md5sum"
md5sum "$LOCALDIR"/* > "$LOCALDIR"/checklist.chk

#echo "Compressing the dump and checklist"
tar -cvzf "$TEMPDIR"/$(date +%Y%m%d)"_"$DATABASEENV"_"$DATABASESCHEMA".tar.gz" "$LOCALDIR"/*

#echo "Sending the compressed file to d2"
## scp "$TEMPDIR"/"$DATABASESCHEMA".tar.gz "$BACKUPHOST":"$REMOTEDIR"

#echo "Removing generated files"
#rm "$LOCALDIR"/checklist.chk > /dev/null 2>&1

#rm "$LOCALDIR"/"$(date +%Y%m%d)_bkp_$DATABASESCHEMA.sql" > /dev/null 2>&1

#rm "$TEMPDIR"/"$DATABASESCHEMA".tar.gz > /dev/null 2>&1

rm "$LOCALDIR"/"$(date +%Y%m%d)_bkp_$DATABASESCHEMA.sql"
echo $(date +%H:%M)

ホスト、ユーザー、パスワード、データベース、LOCALDIR、BACLUPHOST、REMOTEDIRを独自のパラメータに置き換えます。

おすすめ記事