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

相关截图:

  1. 帮助信息

  2. ck结果

  3. al结果

转载于:https://blog.51cto.com/test002/1714804

shell脚本:批量检查并更改MySQL数据库表的存储引擎工作中总结相关推荐

  1. linux下查看mysql数据库的字段类型_系统运维|[小白技巧]如何在Linux上检查MySQL数据表的存储引擎类型...

    提问: 我想要知道我的MySQL数据库是MyISAM还是Innodb类型.我该如何检查MySQL数据库表的类型? MySQl主要使用两种存储引擎:MyISAM 和 Innodb.MyISAM是非事务的 ...

  2. mysql修改存储引擎报错,MySQL改变表的存储引擎

    MySQL提供了多种数据库存储引擎,存储引擎负责MySQL数据库中的数据的存储和提取.不同的存储引擎具有不同的特性,有时可能需要将一个已经存在的表的存储引擎转换成另外的一个存储引擎,有很多方法可以完成 ...

  3. mysql 数据表操作 存储引擎介绍

    一 什么是存储引擎? 存储引擎就是表的类型. mysql中建立的库===>文件夹 库中建立的表===>文件 现实生活中我们用来存储数据的文件有不同的类型,每种文件类型对应各自不同的处理机制 ...

  4. Shell脚本:Linux下定时备份MySQL数据库

    对任何一个已经上线的网站站点来说,数据备份都是必须的.无论版本更新还是服务器迁移,备份数据的重要性不言而喻.人工备份数据的方式不单耗费大量时间和精力,还灰常不专业的说.于是,有了下面这段脚本的出现.参 ...

  5. linux php mysqldump,Linux Shell脚本之利用mysqldump备份MySQL数据库(详细注解)

    利用mysqldump命令备份MySQL数据库的脚本(不带注释版,适合生产环境使用) 设计该脚本的一些设计.编写考虑: 利用mysqldump命令备份MySQL数据库的脚本(不带注释版,适合生产环境使 ...

  6. Linux Shell脚本之利用mysqldump备份MySQL数据库(详细注解)

    设计该脚本的一些设计.编写考虑: 该脚本适用于编译安装mysql和通过yum或apt-get等安装方式 该脚本可以反复执行,不会重复覆盖数据 可增加,删除N天前的备份以节省磁盘空间 充分利用mysql ...

  7. 使用shell脚本更新文本数据至mysql数据库

    1.getgamedesc.sh      功能:插入gamedesc.txt文本中的,以","分割的第1列数据gid和第6列数据desc,到线网mysql数据库中(当字段$des ...

  8. 更改mysql数据库存储引擎_MySQL更改数据库表的存储引擎

    mysql更改 1.查看表的原存储引擎 show create table user; 'user', 'CREATE TABLE `user` (/n `id` int(11) NOT NULL D ...

  9. mysql修改默认的存储引擎

    mysql存储引擎: MySQL服务器采用了模块化风格,各部分之间保持相对独立,尤其体现在存储架构上.存储引擎负责管理数据存储,以及MySQL的索引管理.通过定义的API,MySQL服务器能够与存储引 ...

最新文章

  1. 来聊聊COCO数据集上两大霸榜模型-CBNet和DetectoRS
  2. 树莓派都能做脑机接口了?实时处理8个电极信号,人人用得起 | 开源
  3. cname 别名记录 解析过程_云解析是什么?需要购买吗?
  4. 给窗口设置系统级或窗口级的热键
  5. python格式化字符串%r_Python语法速查:3.字符串格式化
  6. 最新QQ邮箱滑块JS逆向教程
  7. 2db多少功率_话筒的灵敏度:-58dB+(-)2dB表示什么意思,数字大的好,还是小的好呢?...
  8. 2.抽象工厂(Abstract Factory)
  9. 四步帮你分析用户流失原因 - 产品设计GAP模型
  10. 数控机床的十大数控系统,学了这么多年终于全了!
  11. Ubuntu 14.04 安装xvid编码器
  12. mysql书单推荐_MySQL有什么推荐的学习书籍
  13. java开发steam平台_stma(steam平台)
  14. 单个圆孔菲涅耳衍射的matlab模拟,矩孔和圆孔菲涅耳衍射的计算机模拟
  15. Beagleboneblack 中DDS模块驱动源码(AD9833)
  16. IPv6实验5:IPv4到IPv6的过渡
  17. 联合查询(多表查询)
  18. Excel如何在不同日期后面插入空行
  19. 计算机学院写论文格式,写作计算机论文的标准格式是什么
  20. HRRRRRRRRRRPILTRITLE

热门文章

  1. osgearth入门图解-用VC++做一个地球出来
  2. C#访问Access完整增删改查代码
  3. win10安装kafka
  4. 为什么使用hibernate
  5. Hadoop权威指南学习笔记三
  6. KMP,深入讲解next数组的求解(转载)
  7. Linux入门-shell使用技巧
  8. [C++]const 总结
  9. 如何开启和关闭开机自启动
  10. 关于webcontrols的TreeView中转义符的处理问题