MySQL DBA 招聘小结

news/2024/7/5 19:22:09
               

招聘MySQL DBA,与10来个2年MySQL DBA工作经验的朋友交流过,谈谈自己的心得:

各位可以先看下互联网公司的薪资待遇: http://blog.csdn.net/mchdba/article/details/22274351


1   关于2年MySQL DBA经验

     看简历描述公司项目的时候,会写上linux系统维护,mssql server项目,或者oracle data gard项目,一般如果有这些,工作在3年到4年,写上2年专职MySQL DBA管理经验,可以从下面来了解:

(1)复制原理

(2)binlog的日志格式的种类和分别

(3)innodb事务与日志的实现

(4)innodb与myisam的索引实现方式的理解

         .........

         关于基础知识考查点,请参考我整理的基础面试点总结: http://blog.csdn.net/mchdba/article/details/13505701

     个人觉得如果有过真正的2年mysql专职dba经验,那么肯定会在mysql的基本原理上有所研究,因为很多问题都不得不让你去仔细研究各种细节,而自己研究过的细节肯定会记忆深刻,别人问起一定会说的头头是道,起码一些最基本的关键参数比如Seconds_Behind_Master为60这个值60的准确涵义。

可以参考如下官方文档:

http://docs.oracle.com/cd/E17952_01/refman-5.5-en/replication-administration-status.html


2   对于简历中写有熟悉mysql高可用方案

    一般先问他现在管理的数据库架构是什么,如果他只说出了主从,而没有说任何ha的方案,那么就可以判断出他没有实际的ha经验。不过这时候也不能就是断定他不懂mysql高可用,也许是没有实际机会去使用,那么就要问mmm以及mha以及mm+keepalived等的原理实现方式以及它们之间的优势和不足了。


3   对于简历中写有批量MySQL 数据库服务器的管理经验

     这个如果他说有的话,会先问他们现在实际线上的mysql数据库数量有多少,分多少个节点组,最后问这些节点组上面的slow log是如何组合在一起来统计分析的。如果这些他都答对了,那么还有一问,就是现在手上有600台数据库,新来的机器,Mysql都安装好了,那么你如何在最快的时间里面把这600台mysql数据库的mysqld服务启动起来。这个重点在于最快的时间。



4   对于有丰富的SQL优化的经验
    首先问mysql中sql优化的思路,如果能准备说出来,ok,那么就开始问explain的各种参数了,重点是select_type,type,possible_key, ref,rows,extra等参数的各种值的含义,如果他都回答正确了,那么我问file sort的含义以及什么时候会出现这个分析结果,如果这里他也回答对了,那么就准备问profile分析了,如果这里他也答对了,那么就会再问一个问题, 那是曾经tx问的让很多人郁闷不已的问题,一个6亿的表a,一个3亿的表b,通过外间tid关联,你如何最快的查询出满足条件的第50000到第50200中的这200条数据记录。

关于explain的各种参数,请参考: http://blog.csdn.net/mchdba/article/details/9190771

5   对于有丰富的数据库设计经验
     这个对于数据库设计我真的没有太多的经验,也就只能问问最基础的,mysql中varchar(60) 60是啥含义,int(30)中30是啥含义? 如果他都回答对了,那么就问mysql中为什么要这么设计呢? 如果他还回答对了,就继续问int(20)存储的数字的上限和下限是多少?


6  关于mysql参数优化的经验。
    首先问他它们线上mysql数据库是怎么安装的,如果说是rpm安装的,那么就直接问调优参数了,如果是源码安装的,那么就要问编译中的一些参数了,比如my.cnf以及存储引擎以及字符类型等等。然后从以下几个方面问起:
(1)mysql有哪些global内存参数,有哪些local内存参数。
(2)mysql的写入参数需要调整哪些?重要的几个写参数的几个值得含义以及适用场景,比如innodb_flush_log_at_trx_commit,sync_binlog等。
(3)读取的话,那几个全局的pool的值的设置,以及几个local的buffer的设置。
(4)还有就是著名的query cache了,以及query cache的适用场景了,这里有一个陷阱,就是高并发的情况下,比如双十一的时候,query cache开还是不开,开了怎么保证高并发,不开又有何别的考虑?

7  关于事物隔离级别。
这个最起码你得知道那4个隔离级别的名字吧,以及之间的区别,还有你当前自己数据库里面设置的是哪个级别吧。
关于事务隔离级别简单资料,请参考: http://blog.csdn.net/mchdba/article/details/12837427

8  关于熟悉mysql的锁机制。
那么gap锁,next-key锁,以及innodb的行锁是怎么实现的,以及myisam的锁是怎么实现的等。


9  关于熟悉mysql集群的。
  就问了ndbd的节点的启动先后顺序,再问配置参数中的内存配置几个重要的参数,再问sql节点中执行一个join表的select语句的实现流程是怎么走的?
关于mysql集群入门资料,请参考:
http://blog.csdn.net/mchdba/article/details/10544585  
http://write.blog.csdn.net/postlist/1583151/all


10  关于有丰富的备份经验的
就问mysqldump中备份出来的sql,如果想sql文件中,一行只有一个insert .... value()的话,怎么办?如果备份需要带上master的复制点信息怎么办?或者xtrabackup中如何做到实时在线备份的?以及xtrabackup是如何做到带上master的复制点的信息的? 当前xtrabackup做增量备份的时候有何缺陷?
关于replace以及insert的一些小细节,请参考: http://blog.csdn.net/mchdba/article/details/8647560
        

11 关于有丰富的线上恢复经验的
就问你现在线上数据量有多大,如果是100G,你用mysqldump出来要多久,然后mysql进去又要多久,如果互联网不允许延时的话,你又怎么做到恢复单张表的时候保证nagios不报警。如果有人说mysqldump出来1个小时就ok了,那么我就要问问他db服务器是啥配置了,如果他说mysql进去50分钟搞定了,那么我也要问问他db机器啥配置了,如果是普通的吊丝pc server,那么真实性,大家懂得。
然后如果你用xtrabackup备份要多久,恢复要多久,大家都知道copy-back这一步要很久,那么你有没有办法对这一块优化。


12, 线上监控mysql

比如内存,流量,事务数,slow 数等,一般目前比较流行的监控软件有cacti,nagios,zabbix等,监控实现,请参考;
Cacti监控mysql数据库服务器实现过程: http://blog.csdn.net/mchdba/article/details/27404109
Nagios服务器端安装部署详解: http://blog.csdn.net/mchdba/article/details/25654889
Cacti使用安装详解: http://blog.csdn.net/mchdba/article/details/27120605



.............





           

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow


http://www.niftyadmin.cn/n/3653775.html

相关文章

使用Google Web Toolkit减轻AJAX的开发

使用Google Web Toolkit减轻AJAX的开发——使用GWT来创建一个简单的AJAX应用作者:Jeff Hanson,JavaWorld.com,12/13/06Google Web Toolkit(GWT)是一个Java开发框架,用来减轻AJAX(Asynchronous JavaScript and XML)的开发难度。使用…

oracle11g plsql调试存储过程卡死的处理技巧

>> PLSQL调试存储过程卡死有多次进行TEST调试存储过程,在某一个环境动不了,然后卡住,plsql界面进入假死状态了,而这个时候只有在windows里面的任务管理器里面强行关闭plsql的后台进程后,然后再次登录打开plsql&a…

Struts快速入门(五完)

用FormTag初始化ActionForm对象本节早前提到,HTML表单中动作URL被映射到一个配置,并轮流被映射到一个配置。FormTag中由action属性制定的URL被FormTag转换为一个在部署描述符中确定的路径结构URL。对于扩充的映射,这意味着资源扩展和指定的一…

Struts快速入门(三)

利用ActionMapping的命令模式Struts提供一个公开的基于XML语句的方法来说明请求URI中servlet路径与适当的请求处理器之间的映射。这个实现与命令模式[Gof]很相似。以下片断摘自struts-config.xml文件,下列声明用于建立ActionMapping配置对象,它是元素的运…

tomcat 应用Message file 'oracle net mesg Message' is missing问题

1,问题描述同事说crm登录hang住了,tomcat后台应用报错如下:2016-06-28 10:30:11,214 [com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread-#0] WARN [com.mchange.v2.resourcepool.BasicResourcePool] - com.mchange.v2.reso…

Struts快速入门(二)

Struts MVC 语义 我们从关键的Struts抽象概念开始,这是它MVC架构的核心。Struts使用Service to Worker模式实现了MVC模式。[Core]控制器对象控制器被ActionServlet类所实现。它提供一个中心位置来处理全部的终端请求。这就为处理视图和导航管理的控制层提供了更为清…

mongodb 最新版本高可用解决方案-replica sets副本集部署详细过程

Mongodb副本集:NoSQL的产生就是为了解决大数据量、高扩展性、高性能、灵活数据模型、高可用性。但是光通过主从模式的架构远远达不到上面几点,由此MongoDB设计了副本集和分片的功能,先来用用副本集。Mongodb副本集的同步机制:数据…

Struts快速入门(一)

Struts快速入门:它能做什么?它如何做?本文选自《Practical J2EE Application Architecture》的第四章,作者是Nadir Gulzar,并且由McGraw-Hill/Osborne Media(www.osborne.com)于2003年3月出版Published on TheServerSi…