ホームページ >バックエンド開発 >PHPチュートリアル >シェルが毎日自動的に mysql データベースをバックアップする方法の例
推奨される関連する mysql ビデオ チュートリアル: "mysql チュートリアル"
2. , 拡張挿入パラメータとロックテーブルパラメータの総称が一般的に使用されます。
3. -u データベースユーザー名 -p データベースユーザーパスワード -h エクスポートされたファイルのパス; 4. 「date +%F」は、2015-11-05 などの形式でシェルで生成された現在の日付です。したがって、正常にエクスポートされたときに生成されるファイル名は db_2015-11-05.sql です。生成された SQL ファイルをテキスト エディターで開き、テスト データベースをローカルにインポートして、問題があるかどうかを確認します。
3. 再利用しやすいように、より柔軟なシェル スクリプトを整理して作成します。
/usr/bin/mysqldump --opt -ubatsing -pbatsingpw -hlocalhost timepusher > /mnt/mysqlBackup/db_`date +%F`.sql
1. スクリプト ファイル ディレクトリ chmod +x sqlAutoBak.sh を入力して、実行権限を追加します。そうでない場合は、「権限が拒否されました」というエラーが表示されます。報告される
2. ./sqlAutoBak.sh の場合、Windows でファイルの書き込みとアップロードを行うとエラーが報告される可能性があります#!/bin/sh# Database infoDB_USER="batsing"DB_PASS="batsingpw"DB_HOST="localhost"DB_NAME="timepusher"# Others varsBIN_DIR="/usr/bin" #the mysql bin pathBCK_DIR="/mnt/mysqlBackup" #the backup file directoryDATE=`date +%F` # TODO# /usr/bin/mysqldump --opt -ubatsing -pbatsingpw -hlocalhost timepusher > /mnt/mysqlBackup/db_`date +%F`.sql$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME > $BCK_DIR/db_$DATE.sql#还原数据库#用mysql-front导入前一天的 *.sql 文件即可恢复数据
3. 変更後、./sqlAutoBak.sh をアップロードして実行を続けますが、エラーは報告されません。エクスポートされたSQLファイルを再度確認してください。
1. エクスポートされた SQL ファイルを確認し、そのファイル サイズが非常に大きいことを確認します
6. このスクリプトを実行するために Linux のスケジュールされたタスクを設定します。
1. スケジュールされたタスクのリストを編集します
/bin/sh^M: bad interpreter: No such file or directory2. 通常、Web サイトは 5 時にトラフィックが最も少ないため、次の行を挿入します。 。
#!/bin/sh# Database infoDB_USER="batsing"DB_PASS="batsingpw"DB_HOST="localhost"DB_NAME="timepusher"# Others varsBIN_DIR="/usr/bin" #the mysql bin pathBCK_DIR="/mnt/mysqlBackup" #the backup file directoryDATE=`date +%F` # TODO# /usr/bin/mysqldump --opt -ubatsing -pbatsingpw -hlocalhost timepusher > /mnt/mysqlBackup/db_`date +%F`.sql# $BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME > $BCK_DIR/db_$DATE.sql$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME | gzip > $BCK_DIR/db_$DATE.sql.gz# 还原数据库# 把 *.sql.gz 使用gunzip 或 本地的解压软件 解压为 *.sql 文件# 用mysql-front导入前一天的 *.sql 文件即可恢复数据
crontab -e
7. 翌日、自動生成されたSQLファイルが要件を満たしているか確認します
生成されたファイルに問題がなければ、このスクリプトを解凍します。スケジュールされたデータベースのバックアップは完了したとみなされます。生成されたファイルが多すぎると一定のスペースが占有されるため、ファイルを定期的に (たとえば、月に 1 回) クリーンアップすることをお勧めします。
$、補足
00 05 * * * /bin/sh /usr/local/apache/htdocs/timepusher/sqlBak/sqlAutoBak.sh#每天早上 5:00am 执行
関連する推奨事項:
ワンクリックで mysql データベースを自動的にバックアップする方法を説明する 3 つのステップ_MySQL Linux 自動バックアップ MySQL データベースのスクリプト コード_MySQLシェルを使用して mysql データベースを自動的にバックアップする定期的に _MySQL以上がシェルが毎日自動的に mysql データベースをバックアップする方法の例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。