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
  • バックアップディレクトリの作成
    mkdir -p /data/dbback/mysql
    
  • バックアップshellスクリプトの作成
    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の有無を判断し、なければインストールする.
  • cron yum-y install vixie-cron yum-y install crontabsのインストール説明:vixie-cronパッケージはcronのメインプログラムです.crontabsパッケージは、cronデーモンをインストール、アンインストール、または駆動するためのテーブルを列挙するプログラムです.
  • 計画タスク実行コマンドの追加:
    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分おきにコマンドを実行することを意味します.