Linux自动备份MySql数据库

原创 2015年11月26日 16:28:30

数据库备份对于网站平台来说很重要,数据就是金钱,有时候的误操作可能就会导致数据库中数据丢失,有一次我们项目组的一个开发人员错写了一个方法,导致平台中所有商品的全部删除了,幸亏大数据部门的人员对数据三天一备份,才没有造成大的损失,所以数据库备份很重要。但是我们又不想每天自己半夜爬起来对数据库进行备份,所以我们可以编写设置一些东西来进行自动备份。

不过我们现在负责数据库的人员都是自己半夜爬起来备份的,我问他们为什么,他们说自动备份的和手动备份的是有区别的,自动备份的会出现不能用的情况(sql server数据库),对此我表示疑问但没有深究,有待考证。

今天想说的是MySql数据库备份,我们想要的是每天自动备份,并且还要定期删除一些备份,不要在服务器上占用很大空间。首先我们先看MySql的备份命令。

1
mysqldump -u root -p"asdasd" -h127.0.0.1 userinfo > backup.sql;

root是用户名,asdasd是密码,userinfo是你想备份的数据库,然后backup.sql 是备份出来的文件。这样我们可以在Linux利用crontab命令周期性的执行一个备份脚本,脚本里我们还可以对备份文件进行打包压缩,并按照时间命名压缩包,然后删除backup.sql备份文件,并且定期删除删除以前的压缩包,下边看一下这个简单的备份脚本。

1
2
3
4
5
6
7
8
9
10
11
#!/bin/bash
#Program:
#       备份数据库
 
#2015、09、16   xjd
 
 
mysqldump -u root -p"asdasd" -h127.0.0.1 userinfo > backup.sql;
tar cvfz $(date +%Y%m%d).tar.gz backup.sql;
rm -rf backup.sql;
rm -rf $(date -d "5 days ago" +%Y%m%d).tar.gz

首先是备份数据库出来一个backup.sql文件,然后用tar命令进行打包压缩,并按照时间命名,然后删除备份文件,最后删除五天前的备份,这只是一个简单例子,还可以根据自己的需求,进行修改添加功能。编写完脚本之后,我们还需要让脚本定期执行,我用的是crontab命令,crontab -e 进行编辑。

1
0 0  * * * backup.sh &> /dev/null

保存之后,这backup.sh脚本就会一天执行一次,crontab命令不熟悉的自行谷歌百度,还有一点要注意,我们看到最后有一个&>/dev/null 这样一句,这句是为了防止出现“You have new mail in /var/spool/mail/root ”这样的错误,如果没有后边那句,那么每执行一次,linux就想把执行的结果以邮件的形式告诉你,当然如果你需要知道每次运行的结果,你可以配置一下,然后把结果发送到你的邮箱。到这里基本上自动备份的问题我们就完成了。



转自(自己的博客):http://www.luckyxue.com/Technology/20150924014612.html

CentOS Linux下每天自动备份MySQL数据库

1.先在服务器下建文件夹以下3个文件夹: mkdir /backup,mkdir /backup/bakmysql,mkdir /backup/bakmysqlold  在/backup文件夹下建一个...
  • li1246994520
  • li1246994520
  • 2017年02月13日 20:04
  • 339

linux下如何实现mysql数据库每天自动备份定时备份

概述  备份是容灾的基础,是指为防止系统出现操作失误或系统故障导致数据丢失,而将全部或部分数据集合从应用主机的硬盘或阵列复制到其它的存储介质的过程。而对于一些网站、系统来说,数据库就是一切,所以做好数...
  • testcs_dn
  • testcs_dn
  • 2015年09月30日 16:17
  • 43826

linux每天自动备份mysql脚本

http://blog.csdn.net/phpfenghuo/article/details/29931837 定时执行脚本: 1、执行 crontab -e 00 00 * *...
  • wjy397
  • wjy397
  • 2016年11月14日 16:25
  • 2069

用Navicat自动备份mysql数据库

数据库备份很重要,很多服务器经常遭到黑客的恶意攻击,造成数据丢失,如果没有及时备份的话,后果不堪设想。一:备份的目的:做灾难恢复:对损坏的数据进行恢复和还原 需求改变:因需求改变而需要把数据还原到改...
  • u013628152
  • u013628152
  • 2017年02月07日 14:58
  • 4393

CentOS系统mysql数据库自动备份脚本

#!/bin/bash databases=(benshi) basepath='/root/backup/' if [ ! -d "$basepath" ]; then mkdir -p "...
  • qq229596421
  • qq229596421
  • 2016年06月30日 17:30
  • 525

mysql恢复删除的数据库和自动备份数据

公司有个哥们不小心删除了数据库,之前也没有备份,幸好mysql已经开启了binlog 1、less /etc/mysql.cnf log-bin=mysql-bin  如果前面加了#,表示注释了,...
  • seelye
  • seelye
  • 2017年06月27日 17:33
  • 351

Windows定时任务+bat文件+WinRar处理Mysql数据库的定时自动备份

服务器环境 Windows Server 2003 ,服务器上采用的是IIS+mysql的集成工具phpStudy。MySQL的安装目录D:\phpStudy4IIS , WinRAR 安装目录 C:...
  • ydm19891101
  • ydm19891101
  • 2016年09月07日 11:03
  • 762

阿里云定时备份mysql

1、查看磁盘空间情况: 既然是定时备份,就要选择一个空间充足的磁盘空间,避免出现因空间不足导致备份失败,数据丢失的恶果!  存储到当前磁盘这是最简单,却是最不推荐的;服务器有多块硬盘,最好是把备份...
  • ssssny
  • ssssny
  • 2016年09月07日 15:45
  • 1287

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

本例:mysql安装目录:/Data/apps/mysql 1、创建备份目录 cd /Data mkdir /mysql_backup 2、创建备份脚本 touch mysq...
  • navioo
  • navioo
  • 2016年06月17日 14:09
  • 274

Mysql 数据库自动备份Shell脚本

[cpp] view plaincopyprint? #!/bin/bash  #Shell Command For Backup MySQL Database Everyday Aut...
  • yibing548
  • yibing548
  • 2015年09月21日 13:20
  • 1185
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Linux自动备份MySql数据库
举报原因:
原因补充:

(最多只允许输入30个字)