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

备份数据库一直是个非常重要的事情。那么,目前的常见构架方案中。是使用什么办法批量定时备份数据库的呢?答案就是mysqldump和crontab。mysqldump负责导出数据,crontab负责定时执行。下面的命令行是我们这边的运维小哥珍藏很久的代码,被我要来填充文章的。

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

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

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备份数据库 - crontab-db-2

利用mysqldump备份数据库 - crontab-db-3

利用mysqldump备份数据库 - crontab-db-4

利用mysqldump备份数据库 - crontab-db-5

利用mysqldump备份数据库 - crontab-db-6

利用mysqldump备份数据库 - crontab-db-7

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

本站采用创作共用版权协议, 要求署名、非商业用途和相同方式共享。
转载本站内容必须也遵循“署名-非商业用途-相同方式共享”的创作共用协议。
程序如此灵动~》下所有原创文章,如被用于商业用途,请您按规定支付稿费。