运维mysql数据库面试题_运维面试题之数据库

运维mysql数据库面试题_运维面试题之数据库mysql篇:mysql主从复制原理?mysql的复制是基于3个线程1、master上的binlogdump线程负责把binlog事件传到slave2、slave上面的IO线程负责接收binlog事件,并写入relaylog3、save上面的SQL线程负责读取relaylog并执行innodb和myisam引擎的主要区别?InnoDB支持事物,MyISAM不支持InnoDB支持外键,M…

大家好,又见面了,我是你们的朋友全栈君。

mysql篇:

mysql主从复制原理?

mysql的复制是基于3个线程

1、master上的binlog dump线程负责把binlog 事件传到slave

2、slave上面的IO线程负责接收binlog 事件,并写入 relay log

3、save上面的SQL线程负责读取relay log并执行

innodb和myisam引擎的主要区别?

InnoDB支持事物,MyISAM不支持

InnoDB支持外键,MyISAM不支持

InnoDB不支持全文索引,MyISAM支持

InnoDB支持锁行,MyISAM只支持锁表

InnoDB数据存储在表空间,MyISAM存储在文件中

binlog支持哪几种格式?

statement:只记录执行语句

row:记录每行数据的变更过程

mixed:上面两种模式的混合模式,mysql会根据具体的SQL来决定记录statement或者row格式

XtraBackup备份的原理?

直接拷贝表空间文件,由于不锁表所以数据可能会不一致,所以会同时监听mysql的redo log日志变化,redo log包含了InnoDB数据的所有改动情况

在通过redo log对表空间文件进行crash recovery从而生成完整的备份

为什么要用索引?

默认情况下mysql要查找一个数据,需要从第一行数据开始读整个表直到读到到目标数据

索引也是一张表,该表保存了主键与索引字段,并指向实体表的记,有索引的情况下,会先在索引中查找对应的值,然后根据匹配的索引记录找到对应的数据行

redis篇:

redis的数据类型有哪几种?

字符串(String)

哈希(Hash)

列表(List)

集合(Set)

有序集合(sorted set)

reids的线程模型?

redis的IO模型是单线程,使用多路线程I/O复用模型来提升处理效率

使用单线程主要是redis的数据是在内存当中的IO速度很快,多线程会需要切换上下文从而影响CPU性能

redis的持久化策略?

RDB:一快照形式是直接把内存中的数据保存到一个dump文件中,按变更次数定时保存

AOF:redis把所有修改的命令都存到一个文件里

redis的主从复制过程?

先进行一次全量同步,master节点生成RDB文件的快照,slave接收到文件后清除旧数据,然后把文件加载到内存中

当master有写操作时,master使用PSYNC命令连接到slave同步增量数据

reids集群哨兵模式的特性?

监控:每个哨兵会不断监控master和slave是否在正常工作

提醒:如果哨兵监控的redis出了问题,哨兵可以通知管理员和其它应用程序

故障转移:如果master未按预期工作,哨兵可以选举出新的master继续工作

配置程序:客户端需要先连接哨兵,哨兵会告知客户当前master节点的地址

redis事务有什么特点?

redis事务本质上一组命令的集合,其特点就是一次性、顺序性、排他性的执行一个队列中的一系列命令

当一个命令执行失败其它命令还会继续执行,也不能回滚,所以redis的事务不能保证原子性

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/134677.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Python代码画爱心_python代码画人物

    Python代码画爱心_python代码画人物用python一行代码画出爱心print(‘\n’.join([”.join([(‘LoveSongxiaolong'[(x-y)%8]if((x*0.05)**2+(y*0.1)**2-1)**3-(x*0.05)**2*(y*0.1)**3<=0else”)forxinrange(-30,30)])foryinrange(15,-15,-1)]))结果为:…

  • 平面图上的欧拉公式

    平面图上的欧拉公式V-E+F=2,V、E、F表示顶点数、边数、面数。

  • 使用vagrant一键部署本地php开发环境(一)[通俗易懂]

    使用vagrant一键部署本地php开发环境(一)

  • jboss版本_输入法下载

    jboss版本_输入法下载昨天和今天到jboss区下载jboss4.0.4或者其他版本,没有一个下的了,太烂了,网站怎能这样,现在是什么时代呀,免费的或者收费的服务都应该要做的很好才是.感觉现在的软件的功能远远没有达到我心目中理想的位置,也不知何年何月我才对会软件的功能称好!也许软件就是这样吧,开发要成本,做得很好是几乎不可能的了.

  • RabbitMQ 延迟队列实现订单支付结果异步阶梯性通知[通俗易懂]

    RabbitMQ 延迟队列实现订单支付结果异步阶梯性通知[通俗易懂]在第三方支付中,例如支付宝、或者微信,对于订单请求,第三方支付系统采用的是消息同步返回、异步通知+主动补偿查询的补偿机制。 由于互联网通信的不可靠性,例如双方网络、服务器、应用等因素的影响,不管是同步返回、异步通知、主动查询报文都可能出现超时无响应、报文丢失等情况,所以像支付业务,对结果的通知一般采用几种方案结合的补偿机制,不能完全依赖某一种机制。例如一个支付结果的通知,一方面会在支付页…

  • 布隆过滤器原理以及应用_bitmap与布隆过滤器

    布隆过滤器原理以及应用_bitmap与布隆过滤器1.先说下背景,肯定遇到这种情况,判断元素在不在一个集合里面,如果,集合里面的元素非常大,这个判断过程是非常耗时的,而且集合占用空间也很大。2.应用场景,网页黑名单,垃圾邮件过滤,电话黑名单,url去重,内容推荐等。3.原理:布隆过滤器实际上就是一个字节数组,字节数组的值是0或1,在添加元素的时候,对值通过多个hash函数的计算,得到多个0,1然后在字节数组里面在相应的位置设置值。这样处理…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号