linuxでmysqlデータベースのタイミングバックアップを実現
https://www.cnblogs.com/taomylife/p/8022104.html
https://www.cnblogs.com/huxiaoguang/p/10847401.html
https://blog.csdn.net/sinat_33201781/article/details/94443092バックアップディレクトリの作成 バックアップshellスクリプトの作成
まず/etc/my.cnfに以下の内容を追加
etc/myを開く.cnf,[mysqldump]で増加:user=root password=cw 123456 実行可能権限の追加
誤報Warning:Using a password on the command line interface can be insecure.公式サイトhttp://dev.mysql.com/doc/refman/5.1/en/password-security-user.html修正をする.
http://www.jiadingqiang.com/3438.html
上記のスクリプトのユーザー名とパスワードを直接削除し、「mysqldump d b a m e」>「db_name」>「dbn ame」>「backup_dir/d b n a m e」「db_name」>「dbn ame」「time.sql」に変更しますが、プロファイルにユーザー名とパスワードを追加します.my.cnfで指定できます.
etc/myを開く.cnfは、[client]で増加:user=root password=rootですが、これですべてのブロックの操作が共有され、生産環境では安全のためにできるだけ分けることができます(だから[mysqldump]で増加することもできます).
作成タイミングタスク cron yum-y install vixie-cron yum-y install crontabsのインストール説明:vixie-cronパッケージはcronのメインプログラムです.crontabsパッケージは、cronデーモンをインストール、アンインストール、または駆動するためのテーブルを列挙するプログラムです. 計画タスク実行コマンドの追加:
意味
範囲
最初の"*"
1時間の数分目
0-59
2番目の"*"
一日の中の何時間目
0-23
3番目の「*」
一ヶ月のうちの何日目
1-31
4番目の"*"
一年のうちの何月か
1-12
5番目の"*"
1週間のうちの曜日
0-7(0と7は日曜日)
時間
意味
45,22**コマンド
22時45分にコマンドを実行
0 17**1コマンド
毎週1の17時0分にコマンドを実行
0 5 1,15*コマンド
毎月1日と15日の午前5時0分にコマンドを実行します
40 4**1-5コマンド
毎週1~金曜日の午前4時40分にコマンドを実行
*/10 4**コマンド
毎日午前4時、10分おきにコマンドを実行します.
0 0 1,15*1コマンド
毎月1日と15日、毎週1の0時0分にコマンドが実行されます.注意:曜日と何日かは同時に現れないほうがいいです.彼らは天を定義しているからです.管理者を混乱させやすい.
特殊記号
意味
*
いつでも表します.例えば、最初の「*」は、1時間に1分ごとに実行されるという意味です.
,
不連続な時間を表します.例えば「0 8,12,16***コマンド」は、毎日8時0分、12時0分、16時0分に1回のコマンドを実行することを意味します.
-
連続する時間範囲を表します.たとえば、「0 5**1-6コマンド」は、月曜日から土曜日の午前5時0分にコマンドを実行します.
*/n
代表はどのくらいおきに実行しますか.たとえば「*/10****コマンド」は、10分おきにコマンドを実行することを意味します.
https://www.cnblogs.com/huxiaoguang/p/10847401.html
https://blog.csdn.net/sinat_33201781/article/details/94443092
mkdir -p /data/dbback/mysql
vim /data/dbback/bkDatabaseName.sh
次の内容を入力または貼り付けます.まず/etc/my.cnfに以下の内容を追加
etc/myを開く.cnf,[mysqldump]で増加:user=root password=cw 123456
#!/bin/bash
#
db_list="mysql sys test"
#
backup_dir="/data/dbback/back_dir"
#
date=`date +%Y%m%d`
# 7
olddate=`date +%Y%m%d -d "-7 days"`
#
backlog_dir="/data/dbback/back_log"
echo $olddate
#
mkdir -p $backlog_dir/$date
mkdir -p $backup_dir/$date
#
rm -rf $backlog_dir/$olddate
rm -rf $backup_dir/$olddate
for db_name in $db_list
do
echo "$db_name back begin at `date +%H:%M:%S`" >> $backlog_dir/$date/back.log
mysqldump $db_name --skip-lock-tables | gzip > $backup_dir/$date/$db_name"_"$date.sql.gz
echo "$db_name back end at `date +%H:%M:%S`" >> $backlog_dir/$date/back.log
done
echo "all back over!" >> $backlog_dir/$date/back.log
chmod +x bkDatabaseName.sh
実行スクリプト./bkDatabaseName.sh 誤報Warning:Using a password on the command line interface can be insecure.公式サイトhttp://dev.mysql.com/doc/refman/5.1/en/password-security-user.html修正をする.
http://www.jiadingqiang.com/3438.html
上記のスクリプトのユーザー名とパスワードを直接削除し、「mysqldump d b a m e」>「db_name」>「dbn ame」>「backup_dir/d b n a m e」「db_name」>「dbn ame」「time.sql」に変更しますが、プロファイルにユーザー名とパスワードを追加します.my.cnfで指定できます.
etc/myを開く.cnfは、[client]で増加:user=root password=rootですが、これですべてのブロックの操作が共有され、生産環境では安全のためにできるだけ分けることができます(だから[mysqldump]で増加することもできます).
systemctl start crond
systemctl status crond
systemctl enable crond
crontabを検出またはインストールし、コマンドでcrontabの有無を判断し、なければインストールする.crontab -e
viエディタを使用するように、計画タスクを編集できます.次の内容を入力して保存します:(毎日午前1時にデータベースをバックアップ)00 01 * * * /data/dbback/bkDatabaseName.sh
Crontab形式crontabを添付[オプション]オプション:-e:crontabタイミングタスクの編集-l:crontabタスクのクエリー-r:現在のユーザーのすべてのcrontabタスクを削除
1 1~59, * */1 , 00 0
2 1~23(0 0 )
3 1~31
4 1~12
5 0~6(0 )
6
プロジェクト意味
範囲
最初の"*"
1時間の数分目
0-59
2番目の"*"
一日の中の何時間目
0-23
3番目の「*」
一ヶ月のうちの何日目
1-31
4番目の"*"
一年のうちの何月か
1-12
5番目の"*"
1週間のうちの曜日
0-7(0と7は日曜日)
時間
意味
45,22**コマンド
22時45分にコマンドを実行
0 17**1コマンド
毎週1の17時0分にコマンドを実行
0 5 1,15*コマンド
毎月1日と15日の午前5時0分にコマンドを実行します
40 4**1-5コマンド
毎週1~金曜日の午前4時40分にコマンドを実行
*/10 4**コマンド
毎日午前4時、10分おきにコマンドを実行します.
0 0 1,15*1コマンド
毎月1日と15日、毎週1の0時0分にコマンドが実行されます.注意:曜日と何日かは同時に現れないほうがいいです.彼らは天を定義しているからです.管理者を混乱させやすい.
特殊記号
意味
*
いつでも表します.例えば、最初の「*」は、1時間に1分ごとに実行されるという意味です.
,
不連続な時間を表します.例えば「0 8,12,16***コマンド」は、毎日8時0分、12時0分、16時0分に1回のコマンドを実行することを意味します.
-
連続する時間範囲を表します.たとえば、「0 5**1-6コマンド」は、月曜日から土曜日の午前5時0分にコマンドを実行します.
*/n
代表はどのくらいおきに実行しますか.たとえば「*/10****コマンド」は、10分おきにコマンドを実行することを意味します.