设为首页 加入收藏

TOP

shell脚本:<批量检查并更改MySQL数据库表的存储引擎>
2015-11-21 01:24:44 来源: 作者: 【 】 浏览:6
Tags:shell 脚本 < 批量 检查 更改 MySQL 数据库 存储 引擎 >
Work Description: 在搭建完Percona XtraDB Cluster(一种MySQL架构,简称PXC),需要把old mysql中的数据导入到new mysql中,但PXC只支持InnoDB表,非InnoDB表无法同步到PXC的其它节点上,因此我需要批量统一表的引擎。
?
Event Description:
?
1.需要写个shell脚本,完成两个目的:<1>查询(ck)ENGINE的状态 <2>更改(al)引擎状态
?
2.需要在管理机上,访问远程MySQL
?
<方式:mysql -uadmin -h10.10.10.12 -P3001 -ppassword -e"sql_cmd">
?
3.mysql存储引擎的查看方式选择:
?
<1>:select ENGINE from information_schema.TABLES where TABLE_SCHEMA='DB_NAME' and TABLE_NAME=TB_NAME};
?
<2>:SHOW CREATE TABLE tb_name;
?
4.达到目的:
?
<1>:希望执行命令之后,屏幕上能显示<库名、表名、以及引擎状态> 方便直接浏览
?
<2>:表数量很大,希望统计下各引擎表数量并输出,以便分析al时产生的影响
?
<3>:不希望每次al前都执行ck,也不希望ck工程中就al了,我想ck 和al 可以在一起用也可以单独用,这样就灵活了
?
<4>:考虑过写个ip列表的文件,批量对多台机器ck(不太适用我的环境,还要每次vim文件),我希望对单台server 进行ck,这样会比较灵活
?
<5>:我只ck非 系统库表(系统库:mysql,test,information_schema,performance_schema)
?
? ? <6>:执行sh ck_engine_status.sh 后面所跟参数不够,会打印帮助信息
5.脚本check_engine.sh见附件或者链接地址:http://yunpan.cn/cLeVbLN9AnItQ (提取码:08d7)
?
Script Execution And Description:
Execution:
$sh ck_engine_status.sh 10.10.10.12 3001 ck'#查看ENGINE STATUS
$sh ck_engine_status.sh 10.10.10.12 3001 al'#更改ENGINE STATUS
?
Description:
?
1.脚本中需要灵活改动的变量:<用户:USER 密码:PASS> 具有1.远程访问权限?
?
2.select权限 <自己定义:check_log文件路径>
?
2.执行ck,屏幕只会列出engine状态,不会做al
?
3.ck完成之后,自动将MyISAM表以:db_name.tb_name格式写入:check_log中<只涉及MyISAM和InnoDB>
?
4.al会读取check_log中的MyISAM表,并做更改。
?
5.可以手动将特定的表写入check_log中,并执行al
?
相关截图:
?
帮助信息
ck结果
al结果

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇使用RDS必须知道的几点 下一篇Linux下快速安装MongoDB

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: