加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MYSQL数据库MySQL数据库的shell脚本自动备份

发布时间:2020-12-12 01:19:32 所属栏目:MySql教程 来源:网络整理
导读:《MYSQL数据库MySQL数据库的shell脚本自动备份》要点: 本文介绍了MYSQL数据库MySQL数据库的shell脚本自动备份,希望对您有用。如果有疑问,可以联系我们。 MySQL数据库的shell脚本自动备份 MYSQL应用 经常备份数据库是一个好习惯,虽然数据库损坏或数据丢失

《MYSQL数据库MySQL数据库的shell脚本自动备份》要点:
本文介绍了MYSQL数据库MySQL数据库的shell脚本自动备份,希望对您有用。如果有疑问,可以联系我们。

MySQL数据库的shell脚本自动备份MYSQL应用

经常备份数据库是一个好习惯,虽然数据库损坏或数据丢失的概率很低,但一旦发生这种事情,后悔是没用的.一般网站或应用的后台都有备份数据库的功能按钮,但需要去手工执行.我们需要一种安全的,每天自动备份的方法.下面的这个shell脚本就是能让你通过过设定Crontab来每天备份MySQL数据库的方法.MYSQL应用

#!/bin/bash
# 数据库认证
 user=""
 password=""
 host=""
 db_name=""
# 其它
 backup_path="/path/to/your/home/_backup/mysql"
 date=$(date +"%d-%b-%Y")
# 设置导出文件的缺省权限
 umask 177
# Dump数据库到SQL文件
 mysqldump --user=$user --password=$password --host=$host $db_name > $backup_path/$db_name-$date.sql

通过上面的脚本,我们可以每天导出一份sql备份文件,文件的名称按当日日期生成.日积月累,这样的文件会生成很多,有必要定时删除一些老旧的备份的文件,下面的这行命令就是做这个任务的,你可以把它加在上面的脚本后面.MYSQL应用

# 删除30天之前的就备份文件
 find $backup_path/* -mtime +30 -exec rm {} ;

我在使用上面的脚本时曾经遇到过一个问题,Crontab定时执行脚本导出没有报错,但导出的是空的SQL文件,但登录到控制台手工执行这个脚本是备份成功的.后来发现是Crontab执行脚本是缺少系统环境信息,找不到 mysqldump,改正的方法是使用 mysqldump 全路径就行了.而之所以没有报错信息,是因为 mysqldump 把错误信息输出到了 stderr.在命令的后面末尾接 “2>&1” 这样一个信息重定向命令就可以看到错误信息了:MYSQL应用

mysqldump -ujoe -ppassword > /tmp/somefile 2>&1

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!MYSQL应用

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读