【5】阿里面试题整理

news/2025/2/10 13:44:08/

[1]. 介绍一下ZooKeeper

ZooKeeper是一个开源的分布式协调服务,核心功能是通过树形数据模型(ZNode)和Watch机制,解决分布式系统的一致性问题。

它使用ZAB协议保障数据一致性,典型场景包括分布式锁、配置管理和服务注册发现、集群管理等。

ZooKeeper通常以集群的方式部署,由多个ZooKeeper服务器组成。集群中有一个领导者服务器,负责处理客户端的写请求,并将数据同步到其他服务器;其他服务器是追随者,负责处理客户端的读请求。

[2]. ZAB协议

ZAB协议是一种基于Paxos算法的改进协议,专门为ZooKeeper这种分布式协调服务而设计,保证了在ZooKeeper集群中,数据变更能够以原子性和顺序性广播到所有节点,从而实现最终一致性。

ZAB协议主要有两种模式:消息广播模式崩溃恢复模式

在消息广播模式下,Leader接收到客户端的写请求后,会将这个请求封装成一个Proposal广播给所有Follower。Follower收到Proposal后,写入本地事务日志,并向Leader发送ACK确认。当Leader收到超过半数的Follower的ACK后,就认为这个Proposal已经提交,然后Leader会向所有Follower发送Commit命令。

在崩溃恢复模式下,集群会进行Leader选举,选出一个新的Leader,然后新的Leader会从事务日志中恢复数据,并确保所有节点的数据保持一致。

[3]. ZooKeeper的选举机制

ZooKeeper使用一种Leader选举机制来保证集群的高可用性。

当集群启动或Leader服务器发生故障时,就会触发选举。选举过程中,每个服务器都会将自己作为候选Leader进行投票,投票信息包括服务器ID和事务ID(zxid)。

服务器会将自己的投票广播给其他服务器,并接收其他服务器的投票。在接收到投票后,如果发现收到的投票信息中的zxid比自己的大,或者zxid相同但服务器ID比自己的大,则更新自己的投票信息。

最后,每个服务器统计收到的投票信息,如果某个服务器收到了超过半数服务器的投票,则该服务器成为新的Leader。选举过程中,zxid最大的服务器会被优先选为Leader,如果多个服务器的zxid相同,则服务器ID较大的服务器会被选为Leader。

[4]. Memcached的缓存机制

Memcached是一个高性能的分布式内存对象缓存系统,用于加速动态Web应用程序。

Memcached使用哈希表来存储键值对,并使用slab分配机制来管理内存。当Memcached的内存空间不足时,会使用LRU算法来淘汰最近最少使用的数据。

在分布式缓存方面,Memcached通常使用一致性哈希算法来实现数据的分片。

Memcached具有高性能、简单易用、可扩展性强等优点,但同时也存在无持久化机制和内存限制等缺点

[5]. 基本数据类型和包装类的区别

基本数据类型存储在栈中,效率高,占用内存少;包装类存储在堆中,需要更多的内存。

基本数据类型功能简单,只能进行基本运算;包装类提供了丰富的方法,方便操作。

基本数据类型主要用于数值运算等场景;包装类通常用于需要对象的地方,比如集合框架,或者需要使用包装类提供的方法,以及进行类型转换等。


http://www.ppmy.cn/news/1570871.html

相关文章

uniapp使用路由名称跳转

由于web端和app公用一套菜单,而两个项目的路径是不同的,为解决这个问题,封装了一套使用路由名称作为跳转路由的方法 1.在pages.json文件里pages对应的页面配置里添加 routeName 字段(自定义),我做的app里面…

基于lstm+gru+transformer的电池寿命预测健康状态预测-完整数据代码

项目视频讲解: 毕业设计:基于lstm+gru+transformer的电池寿命预测 健康状态预测_哔哩哔哩_bilibili 数据: 实验结果:

Unity3D实现UGUI拖拽移动

系列文章目录 unity工具 文章目录 系列文章目录👉前言👉一、实现原理👉二、方法一👉方法二👉壁纸分享👉总结👉前言 在 Unity UGUI 中实现拖拽移动的功能,主要基于事件系统、坐标转换和位置更新这几个关键步骤,下面详细介绍其原理 博客将会介绍如何实现UGUI拖…

如何将Excel的表格存为图片?

emmm,不知道题主具体的应用场景是什么,就分享几个我一般会用到的场景下奖excel表格保存为图片的技巧吧! 先来个总结: 方法 适用场景 画质 操作难度 截图(WinShiftS) 快速保存表格,方便粘贴…

使用WebUI访问本地Deepseek(Ollama集成Open WebUI)

在《deepseek本地部署和使用(Linux虚拟机)》中,我们使用Ollama部署了Deepseek-r1,但是只能通过命令行方式交互,默认Ollama启动后,会启动一个监听到127.0.0.1,用以接收POST 请求,服务…

C#控件开发6—指示灯

按钮功能:手自动旋转,标签文本显示、点击二次弹框确认(源码在最后边); 【制作方法】 找到控件的中心坐标,画背景外环、内圆;再绘制矩形开关,进行角度旋转即可获得; 【关…

微信小程序案例1——制作猫眼电影底部标签导航栏

文章目录 一、项目步骤1 新建一个无AppID的movie项目2将准备好的底部标签导航图标拷贝到movie项目下面(将图标文件夹image放到项目文件夹里)3 打开App.json配置文件,在pages数组里添加4个页面路径:电影“pages/movie/movie”、影院“pages/cinema/cinema”、发现“pages/find…

VERA: 基于视觉-语言模型的解释性视频异常检测框架

文章目录 速览摘要01 引言1.1 关键观察与研究问题1.2 我们的方法1.3 贡献 02 相关工作2.1 视频异常检测2.2 针对VLM的语言化学习 03 VERA框架3.1 视频异常检测的任务定义3.2 在VERA中通过语言化学习寻找VAD指导性问题训练目标训练数据通过学习者与优化器更新 Q Q Q学习者与优化…