主页 > 知识库 > MySQL数据库的shell脚本自动备份

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

热门标签:遂宁400电话申请 dq8 全地图标注 电销机器人市场价 南宁智能电销机器人价格 邯郸400电话注册办理 地图标注直通车 哈尔滨云外呼系统运营商 永州智能外呼系统 赵县地图标注

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

经常备份数据库是一个好习惯,虽然数据库损坏或数据丢失的概率很低,但一旦发生这种事情,后悔是没用的。一般网站或应用的后台都有备份数据库的功能按钮,但需要去手工执行。我们需要一种安全的,每天自动备份的方法。下面的这个shell脚本就是能让你通过过设定Crontab来每天备份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备份文件,文件的名称按当日日期生成。日积月累,这样的文件会生成很多,有必要定时删除一些老旧的备份的文件,下面的这行命令就是做这个任务的,你可以把它加在上面的脚本后面。

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

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

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

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

您可能感兴趣的文章:
  • HBASE 常用shell命令,增删改查方法
  • shell脚本实现mysql定时备份、删除、恢复功能
  • shell简单处理mysql查询结果的方法
  • 用shell写一个mysql数据备份脚本
  • Shell下实现免密码快速登陆MySQL数据库的方法
  • 通过shell脚本对mysql的增删改查及my.cnf的配置

标签:张家界 阿里 浙江 南宁 鄂州 中卫 上海 定西

巨人网络通讯声明:本文标题《MySQL数据库的shell脚本自动备份》,本文关键词  MySQL,数据库,的,shell,脚本,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《MySQL数据库的shell脚本自动备份》相关的同类信息!
  • 本页收集关于MySQL数据库的shell脚本自动备份的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章