zoukankan      html  css  js  c++  java
  • Linux 使用crontab定时备份Mysql数据库

     项目中数据库的数据是至关重要的!在实际项目中,遇到有客户机房断电导致数据库数据丢失的问题,又因为备份容灾不及时,导致部分数据恢复不了,而刚好这部分丢失的数据对于客户来说又是至关重要的,那么怎么办呢?盲羊补牢,为时晚矣!所以,对应日常数据库的自动备份千万不能马虎!首先想到的是,使用Linux的自动定时任务命令crontab对数据库进行定时备份!

    1、在/home/test创建新脚本文件test_database_backup.sh:

    [root@win7 /]# cd home/test
    [root@win7 test]# touch test_database_backup.sh
    [root@win7 test]# chmod 770 test_database_backup.sh

    2、使用VI工具编写test_database_backup.sh备份数据库脚本内容:

    # Name:test_database_backup.sh
    # This is a ShellScript For Auto DB Backup and Delete old Backup
    #备份地址
    backupdir=/www/test_backup
    #备份文件后缀时间
    time=_` date +%Y_%m_%d_%H_%M_%S `
    #需要备份的数据库名称
    db_name=test
    #mysql 用户名
    #db_user=
    #mysql 密码
    #db_pass=
    #mysqldump命令使用绝对路径
    /home/server/mysql-5.6.21/bin/mysqldump $db_name | gzip > $backupdir/$db_name$time.sql.gz
    #删除7天之前的备份文件
    find $backupdir -name $db_name"*.sql.gz" -type f -mtime +7 -exec rm -rf {} ; > /dev/null 2>&1

    3、在以上脚本中并没有填写db_user,db_pass,那么mysqldump怎么连接数据库呢?

    [root@win7 /]cd /etc
    [root@win7 etc]vi my.cnf
    [mysqldump]
    quick
    max_allowed_packet = 16M
    #在这里输入user及password,在执行mysqldump命令就不用输入用户名和密码了
    user=root
    password=123456

    4、使用crontab创建定时任务

    [root@win7 /]crontab -e

    加入00 02 * * * /usr/bin/sh /home/test/test_database_backup.sh >> /home/test/test_database_backup.log

    再用service crond restart重新启动定时任务服务即可!

  • 相关阅读:
    Jquery.validate.js表单验证插件的使用
    UEditor编辑文章出现多余空行问题的解决办法
    jQuery问题:$XXX is not a function
    PHP+memcache扩展(集成环境wampserver环境下)
    Provider 错误 '80004005' 未指定的错误 /conn.asp,行 23
    PHP+MD5
    Mysql(Mariadb) 基础操作语句 (持续更新)
    什么是存储引擎以及不同存储引擎特点
    微信网页授权(OAuth2.0) PHP 源码简单实现
    字符集和字符集编码详解
  • 原文地址:https://www.cnblogs.com/itsharehome/p/6005012.html
Copyright © 2011-2022 走看看