免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2050 | 回复: 9
打印 上一主题 下一主题

【已解决】mysql定时备份的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-06-29 11:47 |只看该作者 |倒序浏览
本帖最后由 cenalulu 于 2012-07-02 18:02 编辑

各位,我利用mysqldump和crontab进行定时备份.而要备份的数据库有以下的特点,都是以abc_(这是变量的,以后会不断的增加)作为数据库的统一开头.即可能出现的情况就是abc_1 abc_2 abc_*之类的,而在利用mysqldump备份的时候要填入数据库名要写什么呢?我试过单单就abc是不行的,请各位能赐教一下

论坛徽章:
0
2 [报告]
发表于 2012-06-29 12:35 |只看该作者
可以写shell循环

for  i in  `seq 1 10`
do
mysqldump --single-transaction --master-data=2 abc_$i > xxxx
done

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
3 [报告]
发表于 2012-06-29 12:42 |只看该作者
先把所有table name 获得,然后加在 --tables 参数后面

论坛徽章:
0
4 [报告]
发表于 2012-06-29 13:25 |只看该作者
谢谢你的关注,用shell的方法我也想过,不过可能是我在提问的时候描述的不清晰,误导你了,正确的应该是abc_的后面不是简单的数字1234之类的,而是一些英文和数字的字符串,好像,garden,photo,wen2012之类的.所以你那个方法在我个情况行不通回复 2# rucypli


   

论坛徽章:
0
5 [报告]
发表于 2012-06-29 13:26 |只看该作者
应该是数据库名吧?回复 3# cenalulu


   

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
6 [报告]
发表于 2012-06-29 14:08 |只看该作者
回复 5# gzcarlos


    sorry看错了,原来是数据库名,那就是--databases参数

论坛徽章:
223
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-05-10 19:22:58操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:10操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
7 [报告]
发表于 2012-06-29 18:39 |只看该作者
学习一下的说呀

论坛徽章:
0
8 [报告]
发表于 2012-06-29 18:54 |只看该作者
已经解决了,思路就是查找到数据库所在的存放位置,并限定某些特定的关键字来取得所需数据库名后再调用循环并可

论坛徽章:
0
9 [报告]
发表于 2012-06-30 10:04 |只看该作者

论坛徽章:
8
综合交流区版块每周发帖之星
日期:2015-12-02 15:03:53数据库技术版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-09-14 06:20:00金牛座
日期:2014-10-10 11:23:34CU十二周年纪念徽章
日期:2013-10-24 15:41:34酉鸡
日期:2013-10-19 10:17:1315-16赛季CBA联赛之北京
日期:2017-03-06 15:12:44
10 [报告]
发表于 2012-07-02 17:39 |只看该作者
rucypli 发表于 2012-06-29 12:35
可以写shell循环

for  i in  `seq 1 10`



for  i in  `mysql -u"$user" -p"$pwd" -e "show database" | grep abc`
do
mysqldump --single-transaction --master-data=2 $i > xxxx
done
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP