以宝塔面板为例,如何利用mysqldump备份数据库?
发布于 作者:苏南大叔 来源:程序如此灵动~ 我们相信:世界是美好的,你是我也是。平行空间的世界里面,不同版本的生活也在继续...
备份数据库一直是个非常重要的事情。那么,目前的常见构架方案中。是使用什么办法批量定时备份数据库的呢?答案就是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
么,下面是个临时截图。
查看修改当前设置的办法就是:
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
那么上述例子就是我们所需要的所有基础知识。
宝塔面板
下面的截图是,我使用宝塔面板配置同样的事情的截图。话说,这个面板,非常的好用的说。
具体的备份逻辑,可以参考文件:
/www/server/panel/script/backup.py
从上图中,苏南大叔发现,具体的备份脚本中的命令和我们给出的略有不同,不过大同小异。也可以具体学习一下。总的来说,宝塔的面板还是非常贴心好用的。
总结
就是那么回事,不写了。嘿嘿
如果本文对您有帮助,或者节约了您的时间,欢迎打赏瓶饮料,建立下友谊关系。
本博客不欢迎:各种镜像采集行为。请尊重原创文章内容,转载请保留作者链接。
本博客不欢迎:各种镜像采集行为。请尊重原创文章内容,转载请保留作者链接。