シェルスクリプトを使用したMySQLデータベースの自動バックアップ データベースを頻繁にバックアップするのは良い習慣です。データベースの破損やデータの損失の可能性は非常に低いですが、一度そのようなことが起こると、後悔しても仕方がありません。通常、Web サイトやアプリケーションのバックグラウンドでデータベースをバックアップするための機能ボタンはありますが、手動で実行する必要があります。毎日自動的にバックアップする安全な方法が必要です。次のシェル スクリプトは、MySQL データベースを毎日バックアップするように Crontab を設定する方法を示しています。 #!/bin/bash # データベース認証 user="" パスワード="" ホスト="" db_name="" # その他 backup_path="/path/to/your/home/_backup/mysql" 日付=$(日付 +"%d-%b-%Y") # エクスポートされたファイルのデフォルトの権限を umask 177 に設定します # データベースを SQL ファイルにダンプする mysqldump --user=$user --password=$password --host=$host $db_name > $backup_path/$db_name-$date.sql 上記のスクリプトを使用すると、SQL バックアップ ファイルを毎日エクスポートでき、ファイル名はその日の日付に応じて生成されます。時間が経つにつれて、このようなファイルが大量に生成されます。古いバックアップ ファイルを定期的に削除する必要があります。次のコマンドラインはこのタスク用です。上記のスクリプトの後に追加できます。 # 30 日以上経過したバックアップ ファイルを削除します。find $backup_path/* -mtime +30 -exec rm {} \; 上記のスクリプトを使用しているときに、問題が発生したことがあります。Crontab がスクリプトのエクスポートを定期的に実行したときにエラーは発生しませんでしたが、エクスポートされた SQL ファイルは空でした。ただし、コンソールにログインしてスクリプトを手動で実行すると、バックアップは成功しました。後で調べたところ、Crontab 実行スクリプトにシステム環境情報が不足しており、mysqldump が見つからないことがわかりました。修正方法は、mysqldump のフルパスを使用することでした。エラー メッセージがない理由は、mysqldump がエラー メッセージを stderr に出力するためです。エラー メッセージが表示されるように、コマンドの最後に「2>&1」を追加します。 mysqldump -ujoe -ppassword > /tmp/somefile 2>&1 読んでいただきありがとうございます。お役に立てれば幸いです。このサイトをサポートしていただきありがとうございます。 以下もご興味があるかもしれません:
|
>>: 自作メニューをクリックする効果を実現するJavaScript
多くの場合、Web ページ開発を学ぶときに最初に印象に残るのは、html または htm サフィック...
この記事の例では、製品の拡大鏡効果を実現するためのVueの具体的なコードを共有しています。具体的な内...
前回の記事では、次のことを紹介しました。 MySQL8.0.20 インストール チュートリアルとイン...
この記事では、JavaScriptキャンバスでミラーイメージ効果を実現するための具体的なコードを参考...
序文アプリケーション シナリオ: おそらく、内部 Web サイトは外部ユーザーにアクセス可能である必...
具体的なコードは次のとおりです。 <div id="ボックス"> &...
このドキュメントを作成した当時は2019年12月頃で、er2.200が最新バージョンでした。 1.画...
Linux には、マウントされたハードディスクとマウントされていないハードディスクの 2 種類のハー...
MySQL をインストールする必要があるため、インストール手順を以下のように記録します。 自分なり...
導入いつものように、シーンから始めましょう〜インタビュアー:「トランザクションの4つの特性をご存知で...
開発プロセス中に、MySQL データベースを復元した後にデータベース データに文字化けが発生した場合...
序文フロントエンド コードの記述では、「互換性」という言葉から逃れることはできません。過去の PC ...
最近の問題としては、次のような現象があります。システムには、docker run コマンドを継続的に...
1. Apache Tomcat 公式サイトから Tomcat 圧縮パッケージをダウンロードします。...