shell分批修改mysql数据库_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

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.脚本中需要灵活改动的变量: 具有1.远程访问权限 2.select权限

2.执行ck,屏幕只会列出engine状态,不会做al

3.ck完成之后,自动将MyISAM表以:db_name.tb_name格式写入:check_log中

4.al会读取check_log中的MyISAM表,并做更改。

5.可以手动将特定的表写入check_log中,并执行al

相关截图:帮助信息

358159345185a8a4f95af845789f96bf.png

ck结果

1583a1e074fed802736e531bde73d97b.png

al结果

b92d8aa8d1271df319e4f5c51596f7a2.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值