0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

技术大牛分享快手面试面经

小林coding 来源:小林coding 2023-04-15 15:39 次阅读

这段时间分享了很多校招的面经,有很多读者说想看社招的,其实社招面试是基于你的工作项目来展开问的,比如你项目用了 xxx 技术,那么面试就会追问你项目是怎么用 xxx 技术的,遇到什么难点和挑战,然后再考察一下这个 xxx 技术的原理。

今天就分享一位快手社招面经,岗位是后端开发,问题都是基于项目涉及的技术栈去展开聊的,同时最后也会有算法题。

项目

  • 自我介绍+项目介绍
  • 就你负责比较多的项目详细说说,项目背景,data模型,流程,难点和挑战
  • 讲讲项目后端用到的技术栈,比如mq,rpc,缓存啥的
  • 消息队列用过吗,业务场景?
  • 怎么保证消息的有序性?

Redis

Redis有哪些数据类型

回答:String,list,map,set,Zset,stream,hyperloglog。。。

(打断)追问:map怎么扩容,扩容时会影响缓存吗

回答:底层有两个dict,一个dict负责请求,到达负载比例进行扩容,渐进式扩容,一部分一部分转移到新的dict

追问:扩容时访问key怎么处理?

回答:先从旧dict获取key,查不到的话,然后从新的dict获取key

小林补充:

进行 rehash 的时候,需要用上 2 个哈希表了。

798bf1f2-db5a-11ed-bfe3-dac502259ad0.pngimg

在正常服务请求阶段,插入的数据,都会写入到「哈希表 1」,此时的「哈希表 2 」 并没有被分配空间。

随着数据逐步增多,触发了 rehash 操作,这个过程分为三步:

  • 给「哈希表 2」 分配空间,一般会比「哈希表 1」 大 2 倍;
  • 将「哈希表 1 」的数据迁移到「哈希表 2」 中;
  • 迁移完成后,「哈希表 1 」的空间会被释放,并把「哈希表 2」 设置为「哈希表 1」,然后在「哈希表 2」 新创建一个空白的哈希表,为下次 rehash 做准备。

为了方便你理解,我把 rehash 这三个过程画在了下面这张图:

79b89450-db5a-11ed-bfe3-dac502259ad0.pngimg

这个过程看起来简单,但是其实第二步很有问题,如果「哈希表 1 」的数据量非常大,那么在迁移至「哈希表 2 」的时候,因为会涉及大量的数据拷贝,此时可能会对 Redis 造成阻塞,无法服务其他请求

为了避免 rehash 在数据迁移过程中,因拷贝数据的耗时,影响 Redis 性能的情况,所以 Redis 采用了渐进式 rehash,也就是将数据的迁移的工作不再是一次性迁移完成,而是分多次迁移。

渐进式 rehash 步骤如下:

  • 给「哈希表 2」 分配空间;
  • 在 rehash 进行期间,每次哈希表元素进行新增、删除、查找或者更新操作时,Redis 除了会执行对应的操作之外,还会顺序将「哈希表 1 」中索引位置上的所有 key-value 迁移到「哈希表 2」 上
  • 随着处理客户端发起的哈希表操作请求数量越多,最终在某个时间点会把「哈希表 1 」的所有 key-value 迁移到「哈希表 2」,从而完成 rehash 操作。

这样就巧妙地把一次性大量数据迁移工作的开销,分摊到了多次处理请求的过程中,避免了一次性 rehash 的耗时操作。

在进行渐进式 rehash 的过程中,会有两个哈希表,所以在渐进式 rehash 进行期间,哈希表元素的删除、查找、更新等操作都会在这两个哈希表进行。比如,查找一个 key 的值的话,先会在「哈希表 1」 里面进行查找,如果没找到,就会继续到哈希表 2 里面进行找到。

另外,在渐进式 rehash 进行期间,新增一个 key-value 时,会被保存到「哈希表 2 」里面,而「哈希表 1」 则不再进行任何添加操作,这样保证了「哈希表 1 」的 key-value 数量只会减少,随着 rehash 操作的完成,最终「哈希表 1 」就会变成空表。

跳表结构了解吗

回答:第一层是双向链表,会有多层来作为链表的索引

追问:和二叉树有什么区别,从时间复杂度和空间复杂度分析

回答:二叉查找树的时间复杂度是O(logn),空间复杂度是O(n);跳表的时间复杂度是O(log_{k}n),k为跳表索引步长,空间复杂度是O(n)

MySQL

MySQL事务用过吗,应用场景是什么

自己学习的demo里用过,场景:银行转账

追问:假如是跨行转账怎么解决事务

回答:我想一想。。。

小林补充:用分布式事务

(打断)追问:跨行先不说,先说不跨行,先说说单库事务,事务的4个基本特性

回答:原子性,一致性,隔离性,持久性

追问:一致性指的是什么

回答:一致性指的是事务提交前后数据库状态一致,是原子性,隔离性和持久性的整合

追问:隔离级别有哪几种

回答:读未提交,读已提交,可重复读,序列化

追问:可重复读是是什么意思,怎么实现的

同一个事务中多次读取结果一致。通过Read View + MVCC实现,在事务开始时创建一个Read View,之后都用这个Read View。

追问:可重复读具体实现细节

回答:Read View的结构包含(1)当前事务id,(2)active事务id列表,(3)最小active事务id记为min_txn_id,(4)next事务id记为max_txn_id。如果record对应的事务id,小于最小active事务id,直接读;否则读取最小active事务id之前版本的数据(这块的逻辑答得有问题,用语言表达时有点混乱,可以私下多练习练习表达)

小林补充:

我们需要了解两个知识:

  • Read View 中四个字段作用;
  • 聚簇索引记录中两个跟事务有关的隐藏列;

那 Read View 到底是个什么东西?

79df94a6-db5a-11ed-bfe3-dac502259ad0.pngimg

Read View 有四个重要的字段:

  • m_ids :指的是在创建 Read View 时,当前数据库中「活跃事务」的事务 id 列表,注意是一个列表,“活跃事务”指的就是,启动了但还没提交的事务
  • min_trx_id :指的是在创建 Read View 时,当前数据库中「活跃事务」中事务 id 最小的事务,也就是 m_ids 的最小值。
  • max_trx_id :这个并不是 m_ids 的最大值,而是创建 Read View 时当前数据库中应该给下一个事务的 id 值,也就是全局事务中最大的事务 id 值 + 1;
  • creator_trx_id :指的是创建该 Read View 的事务的事务 id

知道了 Read View 的字段,我们还需要了解聚簇索引记录中的两个隐藏列。

假设在账户余额表插入一条小林余额为 100 万的记录,然后我把这两个隐藏列也画出来,该记录的整个示意图如下:

79f36a76-db5a-11ed-bfe3-dac502259ad0.png图片

对于使用 InnoDB 存储引擎的数据库表,它的聚簇索引记录中都包含下面两个隐藏列:

  • trx_id,当一个事务对某条聚簇索引记录进行改动时,就会把该事务的事务 id 记录在 trx_id 隐藏列里
  • roll_pointer,每次对某条聚簇索引记录进行改动时,都会把旧版本的记录写入到 undo 日志中,然后这个隐藏列是个指针,指向每一个旧版本记录,于是就可以通过它找到修改前的记录。

在创建 Read View 后,我们可以将记录中的 trx_id 划分这三种情况:

7a1748d8-db5a-11ed-bfe3-dac502259ad0.pngimg

一个事务去访问记录的时候,除了自己的更新记录总是可见之外,还有这几种情况:

  • 如果记录的 trx_id 值小于 Read View 中的 min_trx_id 值,表示这个版本的记录是在创建 Read View 已经提交的事务生成的,所以该版本的记录对当前事务可见

  • 如果记录的 trx_id 值大于等于 Read View 中的 max_trx_id 值,表示这个版本的记录是在创建 Read View 才启动的事务生成的,所以该版本的记录对当前事务不可见

  • 如果记录的 trx_id 值在 Read View 的

    min_trx_id
    

    max_trx_id
    

    之间,需要判断 trx_id 是否在 m_ids 列表中:

    • 如果记录的 trx_id m_ids 列表中,表示生成该版本记录的活跃事务依然活跃着(还没提交事务),所以该版本的记录对当前事务不可见
    • 如果记录的 trx_id 不在 m_ids列表中,表示生成该版本记录的活跃事务已经被提交,所以该版本的记录对当前事务可见

MySQL binlog,redolog和undolog的区别

回答:从这三种log的功能进行分析,undolog用来做事务回滚;redolog用来处理mysql宕机(或进程挂掉)时的数据恢复;binlog记录所有的数据修改操作,可以用来做全量的数据恢复,主从复制(后一点当时没答出来)。

小林补充:

  1. binlog(二进制日志):记录所有对MySQL数据库的修改操作,包括插入、更新和删除等。binlog主要用于数据恢复到指定时间点或者指定事务。可以使用mysqlbinlog命令将binlog文件解析成SQL语句,从而恢复MySQL数据库的状态。

  2. redolog(重做日志):记录所有对MySQL数据库的修改操作,但是只记录了物理操作,比如页的修改。redolog主要用于MySQL的崩溃恢复,即在MySQL崩溃后,通过重做日志,将数据库恢复到最近一次提交的状态。可以使用 Forcing InnoDB Recovery 来进行崩溃恢复。

  3. undolog(回滚日志):用于记录事务的回滚操作,即在事务执行过程中,如果发生了回滚,会将回滚操作记录到undolog中。undolog主要用于 MySQL 的回滚操作,比如使用ROLLBACK语句回滚事务。undolog是InnoDB存储引擎的特有日志,不同于其他存储引擎。

追问:binlog和redolog做数据恢复的区别

回答:redolog有大小限制,数据可能被覆盖,用来处理紧急数据库故障;binlog是全量操作日志,可以进行做全量的数据恢复。

小林补充:

binlog和redolog都是用于MySQL数据库的日志。它们都可以用于数据恢复,但是它们的使用场景和恢复方法有所不同。

binlog是MySQL的二进制日志,它记录了所有对MySQL数据库的修改操作,包括插入、更新和删除等。binlog可以用于恢复MySQL数据库到指定的时间点或者指定的事务。具体来说,可以使用mysqlbinlog命令将binlog文件解析成SQL语句,然后再执行这些SQL语句,从而恢复MySQL数据库的状态。

redolog是MySQL的重做日志,它记录了所有对MySQL数据库的修改操作,但是只记录了物理操作,比如页的修改。redolog可以用于恢复MySQL数据库的崩溃恢复,即在MySQL崩溃后,通过重做日志,将数据库恢复到最近一次提交的状态。具体来说,可以使用innodb_recovery命令来进行崩溃恢复,该命令会根据重做日志来恢复数据库。

因此,binlog和redolog都可以用于数据恢复,但是它们的使用场景和恢复方法有所不同。binlog主要用于数据恢复到指定时间点或者指定事务,而redolog主要用于MySQL的崩溃恢复。

算法

  • 合并两个有序数组

面试总结

感觉

基础知识答得还行,编程拉了

不足之处

有些地方的表达逻辑不够清晰,代码得多写。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 算法
    +关注

    关注

    23

    文章

    4455

    浏览量

    90756
  • 数据库
    +关注

    关注

    7

    文章

    3591

    浏览量

    63370
  • 代码
    +关注

    关注

    30

    文章

    4555

    浏览量

    66770
  • MySQL
    +关注

    关注

    1

    文章

    775

    浏览量

    26004
  • Redis
    +关注

    关注

    0

    文章

    362

    浏览量

    10494

原文标题:快手面试,一直追着问我。。。

文章出处:【微信号:小林coding,微信公众号:小林coding】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    面试通关技巧样板

    ,新技术岗位会随之产生,迅速把握行业发展、瞄准某项新技术的发展前景,是成功跳槽的第一步。记者发现,很多技术人才一方担忧自己的职业前景,另一方
    发表于 08-07 19:38

    单片机程序员面试求教

    各位前辈好: 小弟后天的要去面试单片机程序员实习,请问有什么较好的,求教,万分跪谢!
    发表于 10-17 16:41

    面试

    讲解您的PPT面试官针对您的项目进行技术提问----硬件开发的,一般要求您把一些关键的细节在白黑板上面画出来,看得出面官们想知道您做的项目的技术细节您懂的程度和技术的含量,这个
    发表于 11-25 20:49

    【CANNON试用体验】面试

    今天不说技术,说面试。上一周一直在深圳面试,没有弄小钢炮。那么就说点面试心得吧。给大家一点点参考意见。这几天,深有体会。[fly]而不死者
    发表于 03-09 14:31

    华为面试改革,你怎么看?

    那些把背得滚瓜烂熟,但是设计和编码能力不行的人,没有硬实力是通不过面试的。现在大家都说:面试造航母,工作拧螺丝, 面试中的知识点在工作中
    发表于 05-06 11:00

    软件开发实习 精选资料分享

    某二线城市金融领域小公司软件开发实习视频分享(面试官没开视频,所以无法眼神交流。。。。。。)前一天HR电话沟通:说看了我的简历,问了我得专业,因为不是计算机专业,就有点怀疑我是否能胜任软件开发
    发表于 07-30 08:14

    CVTE嵌入式面试相关资料分享

    远程面试过程:先是电话突袭面试,相当于笔试,问进程线程,TCP,UDP协议;再是牛客网,在线视频代码编写, 询问算法,比较基础。现场面试过程:一主要问基础,***
    发表于 10-27 06:14

    快手刷粉丝,深度的讲解下快手涨粉技巧的方法

    方法和教程 快手刷粉丝专家,教大家快手如何怎么涨粉丝的几种方法,以强大的技术与丰富的资源为各大快手提供一站式贴心服务,专业打造快手代刷服务,
    发表于 01-25 15:44 9w次阅读

    快手刷评论的作用是什么?

           快手上发布短视频的小伙伴每天苦思冥想,绞尽脑汁的给出创意,给出段子,有的是为了单纯的记录生活的点点滴滴,而有的是为了能够吸引更多的粉丝,成为网红。在一些快手热门短视频的评论区,也聚集
    发表于 03-13 11:26 9314次阅读

    如何快手一键涨粉?

         快手短视频使用的是去中心化的算法机制,想要让自己的作品上热门,就需要不断的推动短视频作品的各项指标到达阀值,才能进入下一步的流量池。其中粉丝量是一个重要的指标,很多作品没有上热门
    发表于 03-14 11:25 1575次阅读

    实用的刷快手粉丝自助平台

        内容视频化已经成为了推广运营的新趋势,快手短视频平台一路稳步走来,现今也加快了商业化的进展。我们以文字、图片、表情包、视频等多种样式传达内容,为了让作品快速获得曝光,快手刷赞,快手刷粉丝
    发表于 03-14 11:37 6.6w次阅读

    [橘子网红助手]快手刷赞没有钱快手如何涨粉丝?

           很多玩快手的小伙伴想要快手刷赞快手涨粉丝,却没有足够的经济能力要如何做呢?目前玩快手的小伙伴大多数为学生,主要涨粉丝的方式还是拍作品和与其他小伙伴互粉来涨粉,也是目前不靠
    发表于 03-22 11:40 4267次阅读

    头部互联网企业快手上市最新消息 快手每股发售最高115港元

    快手上市最新消息分享;1月26日早间,快手科技在港交所发布公告,即日起启动全球发售。 据公告,快手将在全球发售3.65亿股,其中香港发售股份数量为913万股,国际发售股份数量为3.56亿股。
    发表于 01-26 10:45 4340次阅读

    快手正式登陆港交所

    快手正式登陆港交所火爆异常, 短视频IPO第一股快手此次IPO受到市场追捧,成为近期新股发行的人气王,当然跟其背后巨大的群众基础分不开,最新数据显示,快手平均日活跃用户超3亿、月活超7亿;独创
    的头像 发表于 02-05 11:55 1.2w次阅读
    <b class='flag-5'>快手</b>正式登陆港交所

    财经速览:快手总营收811亿 趣睡科技IPO拟募资8亿

    财经速览:快手总营收811亿 趣睡科技IPO拟募资8亿        快手总营收811亿 快手科技发布2021年第四季度及全年业绩公告,根据公告数据显示,快手的用户规模创历史新高。
    的头像 发表于 03-29 17:24 1920次阅读