我们相信:世界是美好的,你是我也是。平行空间的世界里面,不同版本的生活也在继续...

备份数据库一直是个非常重要的事情。那么,目前的常见构架方案中。是使用什么办法批量定时备份数据库的呢?答案就是mysqldumpcrontabmysqldump负责导出数据,crontab负责定时执行。

苏南大叔:以宝塔面板为例,如何利用mysqldump备份数据库? - mysqldump
以宝塔面板为例,如何利用mysqldump备份数据库?(图5-1)

核心命令

下面的命令行是我们这边的运维小哥珍藏很久的代码,被我要来填充文章的。

mysqldump -u username -p -d dbname > dbname.sql        导出数据库结构(不含数据)
mysqldump -u username -p dbname tablename > dbname.sql    导出数据库中的某张数据表(包含数据)
mysqldump -u username -p -d dbname tablename > tablename.sql      导出数据库中的某张数据表的表结构(不含数据)

计划任务

关于crontab么,下面是个临时截图。

苏南大叔:以宝塔面板为例,如何利用mysqldump备份数据库? - crontab-e
以宝塔面板为例,如何利用mysqldump备份数据库?(图5-2)

查看修改当前设置的办法就是:

crontab -e

这个时候,实际上进入的是个vi环境,所以,这个时候是可以修改当前设置的。具体vi命令的使用,以后有机会再说。这里就说说crontab条目最前方的几个星号的用法吧。这个在laravel的高级开发中也会用到,以后我们再聊这个话题。

*  *  *  *  *  command
分  时  日  月  周  命令
第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时0~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令

下面是一些范例:

crontab文件的一些例子:
30 21 * * * /usr/local/etc/rc.d/lighttpd restart
#上面的例子表示每晚的21:30重启apache。
45 4 1,10,22 * * /usr/local/etc/rc.d/lighttpd restart
#上面的例子表示每月1、10、22日的4 : 45重启apache。
10 1 * * 6,0 /usr/local/etc/rc.d/lighttpd restart
#上面的例子表示每周六、周日的1 : 10重启apache。
0,30 18-23 * * * /usr/local/etc/rc.d/lighttpd restart
#上面的例子表示在每天18 : 00至23 : 00之间每隔30分钟重启apache。
0 23 * * 6 /usr/local/etc/rc.d/lighttpd restart
#上面的例子表示每星期六的11 : 00 pm重启apache。
0 */1 * * * /usr/local/etc/rc.d/lighttpd restart
#每一小时重启apache
0 23-7/1 * * * /usr/local/etc/rc.d/lighttpd restart
#晚上11点到早上7点之间,每隔一小时重启apache
0 11 4 * mon-wed /usr/local/etc/rc.d/lighttpd restart
#每月的4号与每周一到周三的11点重启apache
0 4 1 jan * /usr/local/etc/rc.d/lighttpd restart
#一月一号的4点重启apache 

那么上述例子就是我们所需要的所有基础知识。

宝塔面板

下面的截图是,我使用宝塔面板配置同样的事情的截图。话说,这个面板,非常的好用的说。

苏南大叔:以宝塔面板为例,如何利用mysqldump备份数据库? - crontab-db-1
以宝塔面板为例,如何利用mysqldump备份数据库?(图5-3)

苏南大叔:以宝塔面板为例,如何利用mysqldump备份数据库? - crontab-db-5
以宝塔面板为例,如何利用mysqldump备份数据库?(图5-4)

具体的备份逻辑,可以参考文件:

/www/server/panel/script/backup.py

苏南大叔:以宝塔面板为例,如何利用mysqldump备份数据库? - crontab-db-7
以宝塔面板为例,如何利用mysqldump备份数据库?(图5-5)

从上图中,苏南大叔发现,具体的备份脚本中的命令和我们给出的略有不同,不过大同小异。也可以具体学习一下。总的来说,宝塔的面板还是非常贴心好用的。

总结

就是那么回事,不写了。嘿嘿

如果本文对您有帮助,或者节约了您的时间,欢迎打赏瓶饮料,建立下友谊关系。
本博客不欢迎:各种镜像采集行为。请尊重原创文章内容,转载请保留作者链接。

 【福利】 腾讯云最新爆款活动!1核2G云服务器首年50元!

 【源码】本文代码片段及相关软件,请点此获取更多信息

 【绝密】秘籍文章入口,仅传授于有缘之人   crontab    mysqldump