暂无图片
暂无图片
1
暂无图片
暂无图片
暂无图片

[译文] 10 个很棒的 MySQL DBA 面试问题(和答案)

原创 Francisco Bordenave 2021-08-02
3534

DBA 是数据可用性、性能和安全性的重要齿轮。获得优秀的 DBA 是任何公司可以做的最重要的事情之一,以确保其数据库操作继续正常运行。那么如何找到优秀的 DBA?

在这篇文章将展示一些我在面试 DBA 候选人时喜欢问的问题。

性能至关重要,那么这位候选人是否知道如何调整和优化?

1、回到开头:您会推荐哪些最常见的性能优化?

这是关于概念知识的,通常是一个开放式问题。他们是否正在考虑投入硬件和增加资源?这是最简单的解决方案,但通常不是正确的解决方案。如果数据库设计不佳,性能通常会受到限制。他们会谈论这个吗?我希望人们讨论最佳选择并决定哪些变量或修复最有意义。我在客户那里看到的一个简单的答案是调整一个像“innodb_dedicated_server”这样的变量,这当然有帮助,因为它是几种配置的快捷方式,但如果你没有正确理解它,它可能会造成一些不必要的伤害(比如很多不需要的重做日志文件)。我正在寻找能够理解快速问题和持久问题之间的区别的人。

2、为了在受 IO 限制的系统中提高 IO 利用率,您需要调整哪些主要参数?名字3,为什么?

磁盘 IO 是任何数据库中最慢的部分,任何 DBA 都必须了解这个概念。简单的答案始终是添加更多内存,但这不仅仅与缓冲池有关。候选人是否了解影响 IO 的其他变量和数据库内部结构?例如,他们是否了解重做日志、刷新、io_capacity 等,他们是否可以完成他们所做的工作?这些变量的组合将减少 IO 依赖性,同时延长 SSD 寿命。

3、你得到数据库很慢的电话。你做什么工作?您如何识别慢查询?优化查询的最佳策略是什么?

查询优化是每个 DBA 都必须知道的活动。即使数据库在 99% 的时间里看起来都很快且性能良好,一个恶意或缓慢的查询也会导致整个应用程序崩溃。在这里,我们不仅要查找慢查询,还要查找调整和修复它的过程。我们需要了解查询缓慢的原因是什么,例如索引、SQL 编写技巧不佳等。幸运的是,我们有工具可以识别坏人并帮助优化过程。候选人决定使用哪些工具比他们经历的过程更不重要。我们正在寻找诸如识别缺失索引、坏主键、超大表问题、模式设计等的能力。

4、假设您需要将针对 MySQL 服务器的流量增加 10 倍。您的可扩展性策略是什么?读取的缩放比例与写入的缩放比例相同吗?

这里有许多可扩展性策略。您不仅要寻找具体的技术或流程,还要寻找它们背后的原因。需要讨论和深入研究的关键事项:添加副本以卸载流量、设置负载均衡器、增加可用硬件、分片等。所有这些都是有效的策略。真正的问题是候选人是否理解它们以及何时应该使用和不应该使用它们?

每个 DBA 都必须构建并确保他们的数据库系统在需要时可用。因此,了解数据库可用性策略至关重要。必须提出问题来衡量他们的理解:

5、您如何解释异步复制滞后?为什么会出问题?你会怎么修?

异步复制仍然是一个非常重要的主题,虽然随着 MySQL 的每个版本和更改的添加,性能都在不断提高,但我仍在帮助许多客户解决复制设置和滞后问题。许多公司使用副本进行报告、备份和高可用性,因此我们希望我们的副本尽可能保持最新。好消息是这也为候选人提供了另一个跳出框框思考的机会,因为异步复制延迟会受到数据库设计问题的极大影响,例如没有主键、长时间运行的查询、选择更新等。

6、他们能解释异步复制和同步复制之间的区别吗?他们什么时候会选择一个?

当然,您可以在 MySQL 中使用几种不同类型的异步复制(MySQL GTID、MariaDB GTID、Tungsten Replicator)和同步复制(Percona XtraDB Cluster、MySQL Group Replication),因此衡量他们对此的一般知识可能会有所帮助评估他们的技能。虽然这里没有 100% 正确的答案,但重要的是要了解选择一种解决方案的决策驱动因素是什么,例如性能、一致性、可用性等。

7、基于 Galera 的解决方案需要的最少节点数是多少?添加更多节点的利弊是什么?

MySQL 领域有两种主要的集群解决方案。基于 Galera 的复制,如 Percona XtraDB 集群和基于组复制的集群,如 InnoDB 集群。这个问题的关键是要知道 Galera 是为一致性和可用性而设计的,而不是写可扩展性。理解这些差异非常重要,因为“更多的写入者更多的写入”的想法很常见,就好像添加更多的写入者节点可能会增加集群的写入能力一样。

当然,需要确保候选人不仅知道如何排除性能故障和设置高可用性,他们还需要了解一些基本的数据库操作和技术。至少询问一个关于安全性、备份和托管(云与否)的问题是确保您涵盖基础知识的好方法。

8、请描述您推荐的备份策略。您会使用哪些工具以及如何使用?

了解备份的重要性很重要。我正在寻找能够引导我了解他们的经验并告诉我他们认为什么是好的和安全的备份策略的人。在他们交谈时,我会提出问题,看看他们是否了解他们所运行的设置的局限性或好处。我希望他们能够掌握不同的备份选项(物理的、逻辑的)以及可以推荐的备份策略(每日、每周、每月、完整、增量等)。当然,我对人们如何确保他们的备份“良好”很感兴趣。并非所有人都认为还原测试应该被视为备份策略的一部分。

9、部署 MySQL 时,您会遵循哪些基本安全策略?

再次没有一刀切的答案,但毫无疑问,DBA 必须保护公司的数据。需要注意的一些事项:强密码、仅从本地主机进行 root 访问、删除没有密码的用户、删除非管理员用户的 SUPER priv、限制用户访问他们自己的数据库/表、加密数据等。

10、请解释 RDS MySQL 和 Aurora 之间的主要区别。您何时会推荐一种解决方案而不是另一种?

毫无疑问,云已经改变了我们运行数据库的方式。候选人是否对 AWS 的前两个 MySQL 选项之间的差异有基本的了解?他们是不同的,他们知道吗?了解利弊至关重要。虽然 RDS 提供了一种设置异步复制的简单方法,开箱即用,但它需要一些操作活动来确保环境健康,即数据一致性检查、在主故障的情况下处理故障转移等。另一方面。 , Aurora 通过以更高的成本确保一致性和可用性以及一些额外的写入开销来解决操作部分,因此它可能无法在高流量环境中很好地扩展。

这些只是我认为人们在寻找优秀的数据库专业人员时可以提出的一些很好的问题。你有其他的好问题吗?欢迎在评论区一起讨论。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论