zoukankan      html  css  js  c++  java
  • CentOS上Mysql数据库定时全库备份

    如下脚本用于mysql全库定时备份

    mysql_dump_script.sh

     1 #!/bin/bash
     2 
     3 #保存备份个数,最多保留4个文件
     4 number=4
     5 #备份保存路径
     6 backup_dir=/db/backup_mysql
     7 #日期
     8 dd=`date +%Y-%m-%d-%H-%M-%S`
     9 #备份工具
    10 tool=mysqldump
    11 #用户名
    12 username=root
    13 #密码
    14 password=yourpassword
    15 #将要备份的数据库
    16 database_name=mydb
    17 
    18 #如果文件夹不存在则创建
    19 if [ ! -d $backup_dir ]; 
    20 then     
    21     mkdir -p $backup_dir; 
    22 fi
    23 
    24 #简单写法  mysqldump -u root -p123456 users > /root/mysqlbackup/users-$filename.sql
    25 $tool -h127.0.0.1 -u $username -p$password $database_name > $backup_dir/$database_name-$dd.sql
    26 
    27 #写创建备份日志
    28 echo "create $backup_dir/$database_name-$dd.dupm" >> $backup_dir/log.txt
    29 
    30 #找出需要删除的备份
    31 delfile=`ls -l -crt  $backup_dir/*.sql | awk '{print $9 }' | head -1`
    32 
    33 #判断现在的备份数量是否大于$number
    34 count=`ls -l -crt  $backup_dir/*.sql | awk '{print $9 }' | wc -l`
    35 
    36 if [ $count -gt $number ]
    37 then
    38   #删除最早生成的备份,只保留number数量的备份
    39   rm $delfile
    40   #写删除文件日志
    41   echo "delete $delfile" >> $backup_dir/log.txt
    42 fi

    centos 设置crontab

    yum install crontabs
    systemctl enable crond (设为开机启动)
    systemctl start crond(启动crond服务)
    systemctl status crond (查看状态)

    vi /etc/crontab

    添加定时任务

    加载任务,使之生效:

    crontab /etc/crontab

    查看任务:

    crontab -l

  • 相关阅读:
    hive 拉链表
    hive分组排序函数 分组取top10
    Hive metastore三种配置方式
    DB2基础学习3
    DB2基础学习2
    DB2的基础学习
    MySQL的基础学习
    虚拟机克隆,service network restart 重启失败
    两台电脑如何共享文件
    vmware下ubuntu14.04 nat方式上网
  • 原文地址:https://www.cnblogs.com/DevinZhang1990/p/12162383.html
Copyright © 2011-2022 走看看