登录
首页 >  数据库 >  MySQL

Linux下定时备份数据库

来源:SegmentFault

时间:2023-02-16 15:15:37 185浏览 收藏

你在学习数据库相关的知识吗?本文《Linux下定时备份数据库》,主要介绍的内容就涉及到MySQL,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

Linux下定时备份数据库
linux下使用crontab定时备份MYSQL数据库的方法
只需按照下面3步做,一切都在你的掌控之下:

第一步:在服务器上配置备份目录代码:
1 mkdir /var/lib/mysqlbackup
2 cd /var/lib/mysqlbackup
第二步:编写备份脚本代码:
1 vi dbbackup.sh
2 粘帖以下代码,务必更改其中的username,password和dbname。
3 #!/bin/sh
4 mysqldump -uuser -ppassword dbname | gzip > /var/lib/mysqlbackup/dbname

date +%Y-%m-%d_%H%M%S
.sql.gz
5 cd /var/lib/mysqlbackup
6 rm -rf
find . -name '*.sql.gz' -mtime 10
#删除10天前的备份文件
第三步:更改备份脚本权限
1 chmod +x dbbackup.sh
第四步:用crontab定时执行备份脚本代码:
crontab -e
若每天晚上21点00备份,添加如下代码
00 21 * /var/lib/mysqlbackup/dbbackup.sh
会遇到的问题:
1.mysqldump 是备份数据库的命令,不懂直接百度就好。
2.Crontab 是定时任务的命令,如果不懂可以访问http://www.thinkphp.cn/code/1...
3.备份数据首先要确定已经给root设置了密码,否则会报mysqldump执行时Got error: 1045: Access denied for user ‘root’@’localhost’ (using password: YES) when trying to connect
解决办法:
登录mysql客户端

1 mysql -hserverip -uroot -p
2 mysql> use mysql; Database changed
3 mysql> update user set password=password('new password') where user='root'; Query OK, 4 rows affected (0.00 sec) Rows matched: 4 Changed: 4 Warnings: 0
4 mysql> flush privileges; Query OK, 0 rows affected (0.00 sec) //这个命令是给用户赋予了新的权限或者密码,直接读到内存中不需要重启数据库防止出错
5 mysql> quit

文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Linux下定时备份数据库》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表