MySqlデータベースのバックアップを自動的に作成するスクリプトが必要です。このトピックに関する投稿やスクリプトがすでにたくさんあることは知っていますが、ここが私の違いです。
誰かが似たようなものやどこから始めるべきアイデアがありますか?
多くの人とほとんど同じことをしています。
スクリプトは、MySqlデータベースをホストしているマシン(Linuxマシン)で実行する必要があります。
=>このマシン「A」でローカルbashまたはPerlスクリプト(またはその他)「myscript」を作成します
バックアップは、データベースが存在するのと同じサーバーに保存する必要があります。
=>スクリプト "myscript"では、mysqldumpを使用できます。ローカルバックアップから、scpを介してリモートマシンに送信するtarballを作成できます。最後に、バックアップスクリプトをcrontab(crontab -e)に入れることができます。
スクリプト全体を投稿しないので、始めるためのヒントと関数がいくつかあります。スクリプト全体ではうまくいきませんが、それほど遠くはありません。
#!/bin/sh
...
MYSQLDUMP="$(which mysqldump)"
FILE="$LOCAL_TARBALLS/$TARBALL/mysqldump_$db-$SNAPSHOT_DATE.sql"
$MYSQLDUMP -u $MUSER -h $MHOST -p$MPASS $db > $FILE && $GZIP $GZ_COMPRESSION_LEVEL $FILE
function create_tarball()
{
local tarball_dir=$1
tar -zpcvf $tarball_dir"_"$SNAPSHOT_DATE".tar.gz" $tarball_dir >/dev/null
return $?
}
function send_tarball()
{
local PROTOCOLE_="2"
local IPV_="4"
local PRESERVE_="p"
local COMPRESSED_="C"
local PORT="-P $DESTINATION_PORT"
local EXECMODE="B"
local SRC=$1
local DESTINATION_DIR=$2
local DESTINATION_Host=$DESTINATION_USER"@"$DESTINATION_MACHINE":"$DESTINATION_DIR
local COMMAND="scp -$PROTOCOLE_$IPV_$PRESERVE_$COMPRESSED_$EXECMODE $PORT $SRC $DESTINATION_Host &"
echo "remote copy command: "$COMMAND
[[ $REMOTE_COPY_ACTIVATED = "Yes" ]] && eval $COMMAND
}
次に、「日付」より古いファイルを削除するには、man findを調べて、mtimeおよびnewerオプションに焦点を当てます。
編集:前述のように、tarballを簡単に送信し、送信時に削除できるようにするtemprorayファイルを除いて、ローカルバックアップを実行することに特に関心はありません。
回答:cron
説明:
これを使用してsomething.shファイルを作成してみてください。
#!/bin/sh
mysqldump -u root -p pwd --opt db1.sql > /respaldosql/db1.sql
mysqldump -u root -p pwd --opt db2.sql > /respaldosql/db2.sql
cd /home/youuser/backupsql/
tar -zcvf backupsql_$(date +%d%m%y).tgz *.sql
find -name '*.tgz' -type f -mtime +2 -exec rm -f {} \;
ファイルに適切な権限を与える
chmod 700 mysqlrespaldo.sh
または
Sudo chmod 700 something.sh
次に、でcronを作成します
crontab -e
次のように設定します
**0 1 * * *** /home/youruser/coolscripts/something.sh
数字または「*」文字は次の構造を持っていることに注意してください。
Minutes (range 0-59) Hours (0-23) Day of month (1-31) Month (1-12) Day of the week (0-6 being 0=Domingo) Absolute path to script or program to run
これのほとんどは、30分ごとに実行するように設定された1行のcronジョブで実行できます。
mysqldump -u<user> -p<pass> <database> > /path/to/dumps/db.$(date +%a.%H:%M).dump
これにより、30分ごとにデータベースダンプが作成され、毎週、前週のダンプの上書きが開始されます。
次に、スナップショットを保持している別の場所に最新のダンプをコピーする、週に1回実行される別のcronジョブを用意します。
以下のようなシェルスクリプトを作成します。
#!/bin/bash
mysqldump -u username -p'password' dbname > /my_dir/db_$(date+%m-%d-%Y_%H-%M-%S).sql
find /mydir -mtime +10 -type f -delete
ユーザー名、パスワード、およびバックアップディレクトリ(my_dir)を置き換えます。それをfilename.shとしてディレクトリ(Shell_dir)に保存します
次のようなcrontab-eを使用して、毎日実行するようにスケジュールします。
30 8 * * * /Shell_dir/filename.sh
これは毎日午前8時30分に実行され、データベースをバックアップします。また、10日以上経過したバックアップも削除されます。それをしたくない場合は、スクリプトから最後の行を削除してください。
私の好みは AutoMySQLBackup これはDebianに付属しています。それは本当に簡単で、構成可能な毎日のバックアップを作成します。また、毎週、その後は毎月1回のバックアップで保存されます。
私はこれをしばらく実行していましたが、構成と使用は非常に簡単です!
このオープンソースツール、matiri、 https://github.com/AAFC-MBB/matiri を検討してください。これは、Sqlite3のメタデータを使用した同時mysqlバックアップスクリプトです。機能(あなたが求めていた以上のもの...):
完全開示:元のマティリ作者。