内容简介:对于数据库运维人员来说,想要保证数据库在高效平稳的运行就有点像杂技演员在转盘子,需要灵活、专注、能快速做出反应、并且拥有冷静的头脑。数据库几乎是所有能够成功运行系统的核心。而数据库运维人员对组织的数据负责,能找到可依靠的工具来更加高效的管理数据库,并且轻松的维护日常的工作就变得格外重要。数mycli, 命令行操作mysql的智能提示工具。
概述
对于数据库运维人员来说,想要保证数据库在高效平稳的运行就有点像杂技演员在转盘子,需要灵活、专注、能快速做出反应、并且拥有冷静的头脑。数据库几乎是所有能够成功运行系统的核心。而数据库运维人员对组织的数据负责,能找到可依靠的 工具 来更加高效的管理数据库,并且轻松的维护日常的工作就变得格外重要。数 据库运维人员因此需要更好的工具来使得他们的系统平稳运行。那什么工具才是对 MySQL 管理者来说是经过测试并且值得相信的呢? 这里推荐5款mysql的开源工具。
01
Mycli
mycli, 命令行操作mysql的智能提示工具。
提供了代码补全,语法高亮等功能自动通过输入第一个字符检索表名或字段名通过命令行模式其中,命令行模式的好处在于,在有着远程操作或者双重认证等安全限制的环境中,不受制约,而图像化的工具未必好用。
02
Gh-ost
作为一个DBA,大表的DDL的变更大部分都是使用Percona的pt-online-schema-change,其实还有另外一个比较小巧的工具--gh-ost。gh-ost的设计号称无触发器,可监控,可动态调整暂停等,更重要的是切换方案的优秀设计。
通常业内对大表DDL变更的处理方式无外乎三种,一是利用Percona的pt-online-schema-change,Facebook的OSC等三方工具,二是在备库修改通过切换实现滚动变更,三则是升级MySQL到5.6/5.7通过官方Online DDL实现部分变更。然而,引入触发器带来的锁竞争问题,主备切换带来的附加成本以及Online DDL的局限性都不让DBA省心。
那么gh-ost是怎么工作的呢?官方架构图如下:
其有两种工作方式如下:
1. 连接主库直接修改
- 直连主库
- 主库上创建ghost表
- 新表(ghost表)上直接alter修改表结构
- 迁移原表数据到新表
- 拉取解析binlog事件,应用到新表
- cut-over阶段,用新表替换掉原表
2. 连接从库间接应用到主库
连接从库校验完后,在主库创建新表迁移原表数据到新表模拟从库的从库,拉取解析增量binlog应用到主库cut-over阶段,用新表替换掉原表两者不同的点就在于,通过连接从库来进行变更,对主库的性能影响最小。
03
PhpMyAdmin
资历最老并且最成熟的WEB版MySQL工具。允许数据库运维人员通过浏览器对数据表进行操作。而且具有丰富的格式来展示数据。
能够动态地将问题、连接数/进程、流量绘制成图形。并且检测当性能下降时自动提供解决建议的功能。
04
Sqlcheck
在MySQL的反模式中,有兴趣的同学可以看下相关资料(SQL anti-patterns)。
SqlCheck能将够定位的问题分为3类,高风险,中风险,低风险。这个能帮助列出哪些是最影响你效率的问题。你所要做的就是将文件名称当作参数输入到工具中。
05
Orchestrator
orchestrator是一款非常实用的数据复制管理工具。它能够通过抓取数据库主从关系来生成拓扑图。并且可以通过拖拉拽的方式来重构你的数据库关系。这些操作非常安全,不会因为非法操作来损坏数据库。
最后,orchestrator能够恢复当其中的节点发生故障,它应用了状态的概念来正确的恢复并且在适当的时候与主库进行连接。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 开源其 AIOps 落地三大利器
- 开源ETL利器——Kettle的实战教程
- 开源 Docker 管理利器 DockerFly v20170526 发布
- 重磅开源|AOP for Flutter开发利器——AspectD
- 开源诊断利器Arthas ByteKit 深度解读(1):基本原理介绍
- 强大的开源企业级数据监控利器Lepus安装与配置管理
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Spark技术内幕
张安站 / 机械工业出版社 / 2015-9-1
Spark是不断壮大的大数据分析解决方案家族中备受关注的新增成员。它不仅为分布式数据集的处理提供一个有效框架,而且以高效的方式处理分布式数据集。它支持实时处理、流处理和批处理,提供了AllinOne的统一解决方案,使得Spark极具竞争力。 本书以源码为基础,深入分析Spark内核的设计理念和架构实现,系统讲解各个核心模块的实现,为性能调优、二次开发和系统运维提供理论支持;本文最后以项目实战......一起来看看 《Spark技术内幕》 这本书的介绍吧!