mysql 写5w笔数据_这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)...

894b5e45f3951c3836774c0d9f7ff7d7.png

mysql实战知识点1.MySQL的复制原理以及流程

基本原理流程,3个线程以及之间的关联;

1、主:binlog线程记录改变数据的语句,放进master上的binlog中; 2、从:io线程使用start slave之后,负责从master上拉取 binlog 内容,放进自己的relay log中; 3、从:sql执行线程,执行relay log中的语句。

    #主从复制# 

2.MySQL中myisam与innodb的区别

1、InnoDB支持事物,而MyISAM不支持事物; 2、InnoDB支持行级锁,而MyISAM支持表级锁; 3、InnoDB支持MVCC, 而MyISAM不支持; 4、InnoDB支持外键,而MyISAM不支持; 5、InnoDB不支持全文索引,而MyISAM支持; 6、InnoDB引擎的4大特性:插入缓冲(insert buffer)、二次写(double write)、自适应哈希索引(ahi)、预读(read ahead); 7、select count(*) myisam更快,因为myisam内部维护了一个计数器,可以直接调取

    #存储引擎#

3.MySQL中varchar与char的区别以及varchar(50)中的50的涵义 1、varchar与char的区别
char是一种固定长度的类型,varchar则是一种可变长度的类型。
2、varchar(50)中50的涵义
最多存放50个字符,varchar(50)和(200)存储hello所占空间一样,但后者在排序时会消耗更多内存,因为order by col采用fixed_length计算col长度(memory引擎也一样)。
3、int(20)中20的涵义 是指显示字符的长度但要加参数的,最大为255,比如它是记录行数的id,插入10笔资料,它就显示00000000001 ~~~00000000010,当字符的位数超过11,它也只显示11位,如果你没有加那个让它未满11位就前面加0的参数,它不会在前面加0,20表示最大显示宽度为20,但仍占4字节存储,存储范围不变。 4、mysql为什么这么设计
对大多数应用没有意义,只是规定一些工具用来显示字符的个数int(1)和int(20)存储和计算均一样。

    #字段# 

4.问了innodb的事务与日志的实现方式

1、有多少种日志;

错误日志:记录出错信息,也记录一些警告信息或者正确的信息。
查询日志:记录所有对数据库请求的信息,不论这些请求是否得到了正确的执行。
慢查询日志:设置一个阈值,将运行时间超过该值的所有SQL语句都记录到慢查询的日志文件中。
二进制日志:记录对数据库执行更改的所有操作。
中继日志和事务日志
2、事物的4种隔离级别
隔离级别:读未提交(RU)、读已提交(RC)、可重复读(RR)、串行 3、事务是如何通过日志来实现的,说得越深入越好。
事务日志是通过redo和innodb的存储引擎日志缓冲(Innodb log buffer)来实现的,当开始一个事务的时候,会记录该事务的lsn(log sequence number)号; 当事务执行时,会往InnoDB存储引擎的日志
的日志缓存里面插入事务日志;当事务提交时,必须将存储引擎的日志缓冲写入磁盘(通过innodb_flush_log_at_trx_commit来控制),也就是写数据前,需要先写日志。这种方式称为“预写日志方式”

    #事务与日志#


5.MySQL数据库cpu飙升到500%的话他怎么处理?

1、没有经验的,可以不问;
2、有经验的,问他们的处理思路。
列出所有进程  show processlist 观察所有进程  多秒没有状态变化的(干掉)查看超时日志或者错误日志 (做了几年开发,一般会是查询以及大批量的插入会导致cpu与i/o上涨,当然不排除网络状态突然断了,导致一个请求服务器只接受到一半,比如where子句或分页子句没有发送)

    #CPU飙升#

6.MySQL的SQL语句优化?

1、explain出来的各种item的意义
select_type 
表示查询中每个select子句的类型。
type
表示MySQL在表中找到所需行的方式,又称“访问类型”。
possible_keys 
指出MySQL能使用哪个索引在表中找到行,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用。
key
显示MySQL在查询中实际使用的索引,若没有使用索引,显示为NULL。
key_len
表示索引中使用的字节数,通过该列计算查询中使用的索引的长度。
ref 表示上述表的匹配条件,即哪些列或常量被用于查找索引列上的值。 Extra 包含不适合在其他列中显示但十分重要的额外信息
2、profile的意义以及使用场景
查询到 SQL 会执行多少时间, 并看出 CPU/Memory 使用量, 执行过程中 Systemlock, Table lock 花多少时间等等。

    #SQL优化#

7.mysqldump以及xtranbackup的实现原理 1、备份计划
这里每个公司都不一样,您别说那种1小时1全备什么的就行
2、备份恢复时间
这里跟机器,尤其是硬盘的速率有关系,以下列举几个仅供参考
20G的2分钟(mysqldump)
80G的30分钟(mysqldump)
111G的30分钟(mysqldump)
288G的3小时(xtra)
3T的4小时(xtra)
逻辑导入时间一般是备份时间的5倍以上
3、xtrabackup实现原理
在InnoDB内部会维护一个redo日志文件,我们也可以叫做事务日志文件。事务日志会存储每一个InnoDB表数据的记录修改。当InnoDB启动时,InnoDB会检查数据文件和事务日志,并执行两个步骤:它应用(前滚)已经提交的事务日志到数据文件,并将修改过但没有提交的数据进行回滚操作     #备份计划# 8.500台db,在最快时间之内重启? 运用自动化运维工具puppet、dsh命令     #自动化# 9.你是如何监控你们的数据库的?你们的慢日志都是怎么查询的? 监控的工具有很多,例如zabbix,lepus,我这里用的是lepus     #自动化# 10.你们数据库是否支持emoji表情,如果不支持,如何操作? 如果是utf8字符集的话,需要升级至utf8_mb4方可支持     #自动化# 11.你是否做过主从一致性校验? 主从一致性校验有多种工具 例如checksum、mysqldiff、pt-table-checksum等     #工具# 12.你是如何维护数据库的数据字典的? 这个大家维护的方法都不同,我一般是直接在生产库进行注释,利用工具导出成excel方便流通。     #工具# 13.你们是否有开发规范,如果有,如何执行的? 有,开发规范网上有很多了,可以自己看看总结下。     #规范# 14.表中有text类型的大字段,请问你会拆分字段还是放到一起? 拆带来的问题:连接消耗 + 存储拆分空间;不拆可能带来的问题:查询性能;
如果能容忍拆分带来的空间问题,拆的话最好和经常要查询的表的主键在物理结构上放置在一起(分区) 顺序IO,减少连接消耗,最后这是一个文本列再加上一个全文索引来尽量抵消连接消耗。
如果能容忍不拆分带来的查询性能损失的话:上面的方案在某个极致条件下肯定会出现问题,那么不拆就是最好的选择。     #性能# 15.MySQL中InnoDB引擎的行锁是通过加在什么上完成(或称实现)的?为什么是这样子的? InnoDB是基于索引来完成行锁
例如:select * from tab_with_index where id = 1 for update;
for update 可以根据条件来完成行锁锁定,并且 id 是有索引键的列,
如果 id 不是索引键那么InnoDB将完成表锁,并发将无从谈起     #锁# 16.一个6亿的表a,一个3亿的表b,通过外键tid关联,你如何最快的查询出满足条件的第50001到第50200中的这200条数据记录。 1、如果A表TID是自增长,并且是连续的,B表的ID为索引
select * from a,b where a.tid = b.id and a.tid>500000 limit 200;
2、如果A表的TID不是连续的,那么就需要使用覆盖索引.TID要么是主键,要么是辅助索引,B表ID也需要有索引。
select * from b , (select tid from a limit 50000,200) a where b.id = a .tid;

    #大数据#

17.你是如何监控你们的数据库的?你们的慢日志都是怎么查询的? 监控的工具有很多,例如zabbix,lepus,我这里用的是zabbix      #监控# 18.你是否做过主从一致性校验,如果有,怎么做的,如果没有,你打算怎么做? 主从一致性校验有多种工具 例如checksum、mysqldiff、pt-table-checksum等 #主从# 19.MySQL中InnoDB引擎的行锁是通过加在什么上完成(或称实现)的?为什么是这样子的? InnoDB是基于索引来完成行锁 例: select * from tab_with_index where id = 1 for update; for update 可以根据条件来完成行锁锁定,并且 id 是有索引键的列, 如果 id 不是索引键那么InnoDB将完成表锁,并发将无从谈起     #锁# 20.如何从mysqldump产生的全库备份中只恢复某一个库、某一张表? 全库备份 [root@HE1 ~]# mysqldump -uroot -p --single-transaction -A --master-data=2 >dump.sql 只还原erp库的内容 [root@HE1 ~]# mysql -uroot -pMANAGER erp --one-database 可以看出这里主要用到的参数是--one-database简写-o的参数,极大方便了我们的恢复灵活性 那么如何从全库备份中抽取某张表呢,全库恢复,再恢复某张表小库还可以,大库就很麻烦了,那我们可以利用正则表达式来进行快速抽取,具体实现方法如下: 从全库备份中抽取出t表的表结构 [root@HE1 ~]# sed -e'/./{H;$!d;}' -e 'x;/CREATE TABLE `t`/!d;q' dump.sql DROP TABLE IF EXISTS`t`; /*!40101 SET@saved_cs_client=@@character_set_client */; /*!40101 SETcharacter_set_client = utf8 */; CREATE TABLE `t` (   `id` int(10) NOT NULL AUTO_INCREMENT,   `age` tinyint(4) NOT NULL DEFAULT '0',   `name` varchar(30) NOT NULL DEFAULT '',   PRIMARY KEY (`id`) )ENGINE=InnoDBAUTO_INCREMENT=4 DEFAULT CHARSET=utf8; /*!40101 SETcharacter_set_client = @saved_cs_client */; 从全库备份中抽取出t表的内容 [root@HE1 ~]# grep'INSERT INTO `t`' dump.sql INSERT INTO `t`VALUES (0,0,''),(1,0,'aa'),(2,0,'bbb'),(3,25,'helei');

     #备份与恢复#

21.在当前的工作中,你碰到到的最大的 mysql db 问题以及如何解决的? 可以选择一个处理过的比较棘手的案例,或者选择一个老师在课程上讲过的死锁的案例;没有及时 Purge + insert 唯一索引造成的死锁:具体案例可以参考学委笔记。     #问题# 22.谈谈数据库设计经验? 这个对于数据库设计我真的没有太多的经验,我也就只能问问最基础的,mysql 中varchar(60) 60 是啥含义,int(30)中 30 是啥含义? 如果他都回答对了,那么我就问 mysql中为什么要这么设计呢?如果他还回答对了,我就继续问 int(20)存储的数字的上限和下限是多少?这个问题难道了全部的 mysql dba 的应聘者,不得不佩服提出这个问题的金总的睿智啊,因为这个问题回答正确了,那么他确实认认真真地研究了 mysql 的设计中关于字段类型的细节。至于丰富的设计数据库的经验,不用着急,这不我上面还有更加厉害的 dba吗,他会搞明白的,那就跟我无关了。 varchar(60)的 60 表示最多可以存储 60 个字符。int(30)的 30 表示客户端显示这个字段的宽度。 为何这么设计?说不清楚,请大家补充 。 int(20)的上限为 2147483647(signed)或者4294967295(unsigned)。     #经验# 23.Mysql的高可用方案? 我一般先问他现在管理的数据库架构是什么,如果他只说出了主从,而没有说任何 ha的方案,那么我就可以判断出他没有实际的 ha 经验。不过这时候也不能就是 断定他不懂mysql 高可用,也许是没有实际机会去使用,那么我就要问 mmm 以及 mha 以及mm+keepalived 等的原理实现方式以及它们之间的优 势和不足了,一般这种情况下,能说出这个的基本没有。mmm 那东西好像不靠谱,据说不稳定,但是有人在用的,我只在虚拟机上面用过,和mysql-router 比较像,都是指定可写的机器和只读机器。 MHA的话一句话说不完,可以翻翻学委的笔记。

    #高可用#

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

    #数据恢复#

25.Mysql锁机制 gap 锁, next-key 锁,以及 innodb 的行锁是怎么实现的,以及 myisam 的锁是怎么实现的等 。 Innodb 的锁的策略为 next-key 锁,即 record lock+gap lock。是通过在 index 上加 lock 实现的,如果 index 为 unique index,则降级为 record lock,如果是普通 index,则为 next-key lock,如果没有 index,则直接锁住全表。 myisam 直接使用全表扫描

    #锁#

8eed3ab865dd0fec818fdfe97a1f6ea5.gif

383b89bd16734338e22563482502f406.png

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值