设为首页 收藏本站
查看: 605|回复: 0

shell脚本:<批量检查并更改MySQL数据库表的存储引擎>

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-20 09:49:58 | 显示全部楼层 |阅读模式
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> <ck前会自动删check_log>
4.al会读取check_log中的MyISAM表,并做更改。<al后会自动删check_log,避免多次al><al时会先判断log文件是否存在,不存在会报错提示>
5.可以手动将特定的表写入check_log中,并执行al

相关截图:
  • 帮助信息

    QQ截图20151120094910.png
  • ck结果
    QQ截图20151120094925.png
  • al结果
    QQ截图20151120094932.png



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-141391-1-1.html 上篇帖子: 自动化运维-使用Shell脚本简单实现 下篇帖子: shell之functions(对文件内手机号生成MD5)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表