运维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的事务不能保证原子性

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 开启 MySQL 慢查询日志

    开启 MySQL 慢查询日志开启MySQL慢查询日志开启mysql的慢查询日志,可以记录查询超过指定时间的sql语句,可以方便更好的优化数据库系统的性能。一、参数说明slow_query_log:慢查询日志开启状态slow_query_log_file:慢查询日志存放位置long_query_time:查询超过多少秒才记录二、设置步骤1、查询相关参数配置mysql>showvariab…

    2022年10月9日
    3
  • 传统蓝牙HCI流控(HCI flow control)

    传统蓝牙HCI流控(HCI flow control)一.声明本专栏文章我们会以连载的方式持续更新,本专栏计划更新内容如下:第一篇:蓝牙综合介绍,主要介绍蓝牙的一些概念,产生背景,发展轨迹,市面蓝牙介绍,以及蓝牙开发板介绍。第二篇:Transport层介绍,主要介绍蓝牙协议栈跟蓝牙芯片之前的硬件传输协议,比如基于UART的H4,H5,BCSP,基于USB的H2等第三篇:传统蓝牙controller介绍,主要介绍传统蓝牙芯片的介绍,包括射频层(RF),基带层(baseband),链路管理层(LMP)等第四篇:传统蓝牙host介绍,主

    2022年6月6日
    94
  • Python迭代器

    为方便日后查询和学习,关于Python迭代器的内容将从可迭代对象、迭代器和从迭代器到序列三个方面总结1.可迭代对象a.Python中经常使用for…in…来对某个对象进行遍历,此时被遍

    2021年12月18日
    41
  • c语言自定义BOOL函数

    c语言自定义BOOL函数C语言中没有BOOL类型变量,它是C++独有的,由于使用BOOL类型可以使代码更具有可读性,很多编程者都在C中自己定义了类似的应用,一般方法有两种:第一种:采用宏定义方式typedefintBOOL;#definetrue1#definefalse0或写为:#ifndefbool#defineboolint#endif#ifndeftrue…

    2022年5月30日
    89
  • ant-design-vue文档_antdesign原型设计

    ant-design-vue文档_antdesign原型设计antdesignofvue文件上传action设置上传的地址headers设置上传的请求头部fileList接收已经上传的文件列表(受控)可以控制文件数量事件change记录上传文件改变时的状态,当status为‘done’时将文件列表的地址存到表单中,随表单提交至后台数据库具体用法参考antdesign官网:https://www.antdv.com/components/upload-cn/…

    2022年8月15日
    8
  • C#使用NPOI 导出Excel

    C#使用NPOI 导出ExcelC#使用NPOI导出Excel首先需要添加NPOI的引用//创建Excel文件的对象HSSFWorkbookbook=newHSSFWorkbook();//添加一个sheetIRowrow2=sheet1.CreateRow(0);row2.CreateCell(0).SetCellValue(“序号”);row2.CreateCell(1).SetC

    2022年6月17日
    25

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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