面试技术栈 —— 2024网易雷火暑期实习真题

面试技术栈 —— 2024网易雷火暑期实习真题

  • 1. 最长递增子序列。
  • 2. 集中限流和单机限流你觉得哪个好?
  • 3. redis部署服务器配置,为什么不用哨兵?
  • 4. 讲讲分布式session的原理。
  • 5. 数据库:表数据量大了,如何分表?
  • 6. Raft选举的过程,raft选举平票咋办?
  • 7. java轻量级锁的原理?
  • 8. 轻量级锁线程队列太多了不会影响效率吗?
  • 9. 压测咋测的?
  • 10. redis持久化的原理?
  • 11. 短链生成的原理,短链会重复吗?
  • 12. 动态代理的几种方式区别?
  • 13. Redis的内存模型?
  • 14.过滤器和拦截器的区别?
  • 15. @Controller与@RestController的区别?

1. 最长递增子序列。

题目链接:最长递增子序列 - leetcode
题目描述:
给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。

解题思路:
解法: 最长递增子序列 - leetcode官方题解

class Solution:def lengthOfLIS(self, nums: List[int]) -> int:n = len(nums)if n == 0:return 0dp = [0] * ndp[0] = 1ans = 1for i in range(1,n):dp[i] = 1for j in range(0,i):if nums[j] < nums[i]:dp[i] = max(dp[i], dp[j]+1)ans = max(ans, dp[i])return ans

2. 集中限流和单机限流你觉得哪个好?

在这里插入图片描述

在微服务架构中,集中限流和单机限流是两种常见的限流策略,它们用于控制服务的访问频率,以防止系统过载。

集中限流,也称为分布式限流,是一种服务级的限流策略。它限制对整个微服务集群的访问频率,而不是针对集群中的单个实例。例如,它可以限制特定的调用方,每分钟最多请求多少次某个服务。这种策略允许不同的调用方对不同的接口执行不同的限流规则,因此更适合进行细粒度限流或访问配额管理。集中限流既可以使用单机限流算法,也可以使用分布式限流算法。

单机限流则是一种更细粒度的限流策略,它独立地对集群中的每台实例进行接口限流。例如,它可以限制每台实例接口访问的频率为最大1000次/秒。这种策略的主要目的是防止突发流量压垮单个服务器,因此更适合针对并发进行限制。单机限流一般使用单机限流算法。

从保证系统可用性的角度来看,单机限流更具优势,因为它可以防止个别实例因过高的流量而崩溃。然而,从防止某个调用方过度竞争服务资源的角度来看,集中限流更加适合,因为它可以对不同的调用方实施不同的限流规则。

在实际应用中,可以根据具体的需求和场景选择适当的限流策略。例如,如果API网关是单实例部署,那么使用单机限流算法可能更为合适。

参考文章或视频链接
[1] 《今天一定要搞清楚限流、熔断和降级》
[2] 《10张图带你彻底搞懂限流、熔断、服务降级》
[3] 如何理解微服务中的服务熔断、降级、限流? - bilibili
[4] Set Requests and Limits of a Microservice
[5] MicroService Patterns: Rate Limiting with Spring Boot

3. redis部署服务器配置,为什么不用哨兵?

一般来说,Redis是不需要哨兵服务的。Redis本身支持多实例,只要在多服务器上跑一个Redis实例就可以支持客户端跨节点访问,不需要哨兵服务的支持。

参考文章或视频链接
[1] 讲的很好 【趣话Redis第三弹】Redis的高可用是怎么实现的?哨兵是什么原理?
[2] 本问题答案 Redis是否需要哨兵服务(redis 需要哨兵吗)

4. 讲讲分布式session的原理。

分布式Session是指将用户会话数据存储在多个服务器上,以实现负载均衡和高可用性。在传统的单服务器会话管理中,Session数据通常只存储在一个服务器上,这会导致单点故障和性能瓶颈的问题。而分布式Session通过将会话数据分布到多个服务器上,可以有效地解决这些问题。

分布式Session的原理通常涉及以下几个方面:

  • 会话数据存储:分布式Session通常使用分布式缓存或数据库来存储会话数据。常见的分布式缓存包括Redis、Memcached等。这些缓存服务器可以在多个节点之间进行数据同步和备份,保证数据的高可用性和一致性。
  • 会话数据共享:为了保证不同服务器之间的会话数据共享,可以采用一些技术手段,如Session复制、Session共享和基于缓存的Session共享等。其中,Session复制是指将Session数据复制到多个服务器上,以保证数据的一致性;Session共享是指多个服务器共享同一个Session数据,可以通过负载均衡器将用户的请求分发到任意一个服务器上;基于缓存的Session共享则是将会话数据存储在缓存服务器中,各个服务器通过缓存服务器来获取和更新Session数据。
  • 会话数据路由:为了保证用户的请求能够正确地路由到存储了其Session数据的服务器上,可以采用一些路由算法,如基于Hash的路由算法、基于一致性Hash的路由算法等。这些算法可以根据用户的IP地址、请求参数等信息计算出应该路由到哪个服务器上,从而保证用户能够正确地获取到其Session数据。
  • 通过分布式Session的实现,可以实现用户会话数据的高可用性和负载均衡,提高系统的性能和稳定性。同时,也需要注意数据的安全性和一致性,避免因为数据不一致或者数据丢失等问题导致用户体验的下降。

5. 数据库:表数据量大了,如何分表?

以MySQL为例,首先要知道MySQL的InnoDB引擎用的是B+树结构作为索引,数据量大,就会导致B+树的高度增加,磁盘I/O次数增加,这是查询变慢的根本原因。

  • 水平分表:水平分表也称为数据分片,是将一个表中的记录分散到多个结构相同的表中。通常,这些表会存在于不同的物理存储中。水平分表可以通过多种方式进行,例如根据某个字段的哈希值、范围或列表进行分片。
  • 垂直分表:垂直分表是将一个表中的列分散到多个不同的表中。这些表通常具有不同的结构,但它们之间通过某些字段进行关联。垂直分表可以帮助减少单个表的列数和复杂性,提高查询性能。
  • 按照时间分表:对于包含时间戳的表,可以根据时间范围将数据分散到不同的表中。例如,每个月或每年创建一个新表,将对应时间范围内的数据存储在相应的表中。
  • 按照哈希值分表:通过对某个字段进行哈希运算,将哈希值映射到不同的表中。这种方法可以确保数据在多个表之间均匀分布,提高查询性能。
  • 按照范围分表:根据某个字段的值范围将数据分散到不同的表中。例如,根据用户ID的范围将用户数据分散到多个表中。

6. Raft选举的过程,raft选举平票咋办?

首先,节点有3个状态,级别由低到高分别为:Follower、Candidate、Leader。
其次,选举过程为,设置随机超时时间,先达到超时时间的Follower成为Candidate并任期加1,当该Candidate获得半数选票以上,则该节点成为Leader。

最后,若Candidate平票,由于在成为Candidate时会重置并随机选举超时时间,先到达选举超时的时间的就退出选举,这样就避免了平票。

参考文章或视频链接
[1] 【码农Mark】Raft 分布式一致性算法的动画演示 - bilibili
[2] Raft分布式一致性算法原理(选举和同步) - 知乎

7. java轻量级锁的原理?

Java中的轻量级锁(Lightweight Locking)是一种基于CAS(Compare-And-Swap)操作的锁机制,也被称为自旋锁(Spinlock)。与重量级锁(如ReentrantLock)相比,轻量级锁在获取锁失败时不会使线程进入阻塞状态,而是让线程在一个循环中不断地尝试获取锁,直到成功为止。这种机制避免了线程切换的开销,因此被称为“轻量级”。

轻量级锁的实现通常涉及以下关键步骤:

获取锁:当一个线程尝试获取锁时,它会先检查锁是否已经被其他线程持有。如果锁未被持有,该线程会尝试使用CAS操作将锁的状态设置为已持有。如果CAS操作成功,则该线程获得锁并继续执行。
自旋:如果CAS操作失败(即锁已被其他线程持有),则该线程会进入一个自旋循环,不断检查锁的状态。在自旋循环中,线程会不断尝试使用CAS操作获取锁,直到成功为止。为了避免忙等待(busy-waiting)带来的性能问题,自旋循环通常会设置一个最大自旋次数或自旋超时时间。
等待与唤醒:如果自旋失败,或者自旋超过了设定的最大次数/超时时间,该线程会放弃获取锁,并可能进入等待队列。当持有锁的线程释放锁时,它会唤醒等待队列中的一个线程,使其有机会获取锁。
Java中的java.util.concurrent.locks.AbstractQueuedSynchronizer(AQS)是实现轻量级锁的核心框架。AQS通过内部状态(state)来表示锁的状态,并使用CAS操作来原子地更新状态。AQS还提供了等待队列(Wait Queue)和条件队列(Condition Queue)来支持线程间的同步。

使用轻量级锁时需要注意以下几点:

轻量级锁适用于竞争不激烈的情况,如果锁竞争激烈,可能导致大量线程自旋消耗CPU资源。
轻量级锁通常用于短期锁定,避免长时间持有锁导致其他线程长时间等待。
在使用轻量级锁时,应尽量避免死锁和活锁等并发问题。
总之,Java中的轻量级锁是一种基于CAS操作的锁机制,通过自旋和等待队列来实现线程间的同步。它在竞争不激烈的情况下具有较高的性能优势,但在竞争激烈时可能导致性能问题。因此,在使用轻量级锁时需要根据实际情况进行权衡和选择。

8. 轻量级锁线程队列太多了不会影响效率吗?

如果线程队列中的锁数量过多,线程之间的切换和调度仍然会消耗CPU资源。当线程数量很多时,这种切换和调度的开销可能会变得相当显著,从而降低系统的整体效率。

此外,过多的轻量级锁还可能导致死锁或活锁(一个线程不停自旋尝试获取锁就是活锁,活受罪)的情况,进一步降低系统的性能。

因此,在设计并发系统时,需要权衡线程的数量和锁的使用,避免过多地使用轻量级锁,以提高系统的整体效率。

9. 压测咋测的?

Jmeter软件压测,多组多线程压测。

10. redis持久化的原理?

Redis的持久化是其为了保证数据在故障或重启后不会丢失而设计的一种机制。具体来说,Redis提供了两种持久化方式:RDB(快照)AOF(Append Only File,追加日志文件)日志

RDB持久化:这种方式是通过生成数据快照来实现的。当满足一定条件时(如指定时间内的改动键的数量大于配置中的指定值),Redis会自动将内存中的所有数据快照存储到磁盘中。这个快照是内存数据的二进制序列化形式,存储上非常紧凑。RDB持久化是Redis的默认持久化方式。

AOF持久化:这种方式是通过记录每次对服务器写的操作来实现的。当服务器重启时,会重新执行这些命令来恢复原始的数据。AOF日志记录的是内存数据修改的指令记录文本。由于AOF日志在长期的运行过程中会变得很大,所以在数据库重启时需要加载AOF日志进行指令重放,这可能会需要很长时间。因此,需要定期进行AOF重写,给AOF日志进行瘦身。

11. 短链生成的原理,短链会重复吗?

短链生成通常是通过一定的算法将长链接转换为短链接,以便于分享和传播。这个过程与Redis持久化的机制无关。

至于是否会重复,这主要取决于短链生成的算法和设计。如果短链生成算法设计得当,那么生成的短链应该是唯一的,不会重复。然而,如果短链生成算法存在缺陷或者设计不当,那么就有可能出现短链重复的情况。这与Redis持久化无关,是短链生成算法自身的问题。

参考文章或视频链接
[1] Java——JDK动态代理
[2] 【java常问面试题】场景面试题:如何设计一个短链系统?- bilibili
[3] 短链接是怎么设计的?带你入门 - CSDN

12. 动态代理的几种方式区别?

JDK原生动态代理:

  • (1)该类需要实现一个接口。
  • (2)通过Proxy.newProxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h)静态方法进行代理。
  • (3)其中InvocationHandler h需要实现一个invoke(Object proxy, Method method, Object[] args)钩子方法,具体的代理逻辑就在这个invoke中。
参考文章或视频链接
[1] Java——JDK动态代理

13. Redis的内存模型?

参考文章或视频链接
[1] 深度学习Redis(1):Redis内存模型

14.过滤器和拦截器的区别?

过滤器和拦截器都是用于处理应用程序中的请求和响应的组件,但它们在实现方式、使用场景和功能上存在一些区别。

实现方式:过滤器(Filter)是基于Servlet规范实现的,依赖于Servlet容器,而拦截器(Interceptor)是基于Java反射机制实现的,不依赖于Servlet容器。因此,过滤器是Servlet规范的一部分,而拦截器是Spring框架提供的功能。

使用场景:过滤器通常用于处理所有进入容器的请求和响应,包括静态资源和动态请求。而拦截器通常用于处理Spring框架中的Action请求,主要对业务逻辑层进行拦截。

功能:过滤器主要用于执行一些预处理和后处理任务,例如身份验证、日志记录、字符集设置等。而拦截器不仅可以执行类似的任务,还可以访问Action上下文、值栈中的对象,并且可以获取IOC容器中的各个bean,执行一些业务逻辑。

综上所述,过滤器和拦截器在实现方式、使用场景和功能上存在一定的区别。过滤器主要基于Servlet规范实现,用于处理所有进入容器的请求和响应,主要执行一些预处理和后处理任务;而拦截器基于Java反射机制实现,主要用于处理Spring框架中的Action请求,并可以执行更复杂的业务逻辑。
在这里插入图片描述
在这里插入图片描述

参考文章或视频链接
[1] 【Spring学习】过滤器和拦截器 - 知乎
[2] 拦截器和过滤器区别 - CSDN
[3] 16-拦截器interceptor实现登录校验 - bilibili

15. @Controller与@RestController的区别?

功能:
@Controller注解用于标识一个类是Spring MVC的控制器处理器,它可以处理用户发送的请求并返回视图或模型数据。通常在使用@Controller注解时,方法返回的是一个视图名称或模板文件,如JSP、FTL、HTML等。
@RestController 注解是@Controller的一个特殊变体,它主要用于构建RESTful风格的Web服务。与@Controller不同,@RestController注解的方法返回的是数据,通常是以JSON、XML等形式进行输出,而不是视图。在默认情况下,@RestController注解下的方法返回的对象会被转换为JSON或XML格式的响应,并通过HTTP响应直接返回给客户端,而不进行视图解析。

使用:
@Controller 注解下,开发者通常需要手动配置视图解析器来将方法返回的字符串解析为相应的视图文件。例如,在Spring MVC中,开发者需要配置一个InternalResourceViewResolver来将返回的字符串解析为JSP文件。
@RestController 注解下,开发者无需手动配置视图解析器,因为返回的数据会被直接转换为JSON或XML格式的响应。这使得@RestController注解更适合用于构建RESTful风格的Web服务。

总之,@Controller和@RestController的主要区别在于它们的功能和使用方式。@Controller主要用于处理用户请求并返回视图,而@RestController则主要用于构建RESTful风格的Web服务并返回数据,因此后者@RestController更适合前后端分离。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/682799.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 读取pdf文件

Python 实现读取pdf文件简单示例。 安装命令 需要安装操作pdf的三方类库&#xff0c;命令如下&#xff1a; pip install pdfminer3K 安装过程如下&#xff1a; 引入类库 需要引入很多的类库。 示例如下&#xff1a; import sys import importlib importlib.reload(sys)fr…

cordic算法圆周系统计算sin、cos、平方和开根、atan、坐标系变换

cordic算法圆周系统计算sin、cos、平方和开根、atan 一、cordic圆周系统旋转模式和向量模式1.1 旋转模式1.2 向量模式 二、一些需要考虑的事项2.1角度范围2.2输入正负2.3关于迭代精度2.4坐标系旋转 参考文献&#xff1a; 若想计算 s i n sin sin、 c o s cos cos、 x 2 y 2 \s…

【MySQL】索引事务

MySQL索引事务 1. 索引1.1 概念1.2 作用1.3 使用场景1.4 使用1.5 案例 2. 事务2.2 事物的概念2.3 使用 3. 内容重点总结 1. 索引 1.1 概念 索引是一种特殊的文件&#xff0c;包含着对数据表里所有记录的引用指针。可以对表中的一列或多列创建索引&#xff0c; 并指定索引的类…

【leetcode热题100】不同的二叉搜索树

给你一个整数 n &#xff0c;求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种&#xff1f;返回满足题意的二叉搜索树的种数。 示例 1&#xff1a; 输入&#xff1a;n 3 输出&#xff1a;5示例 2&#xff1a; 输入&#xff1a;n 1 输出&#xff1a;1 …

算法学习——LeetCode力扣回溯篇2

算法学习——LeetCode力扣回溯篇2 40. 组合总和 II 40. 组合总和 II - 力扣&#xff08;LeetCode&#xff09; 描述 给定一个候选人编号的集合 candidates 和一个目标数 target &#xff0c;找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字…

Qt 的准备知识

文章目录 1. Qt 背景介绍2. 搭建 Qt 开发环境3. 认识 Qt Creator3.1 main.cpp3.2 widget.h3.3 widget.cpp3.4 Forms3.5 .pro文件 1. Qt 背景介绍 Qt 是⼀个 跨平台的 C 图形用户界面应用程序框架 。它为应用程序开发者提供了建立艺术级图形界⾯所需的所有功能。它是完全⾯向对…

Docker 在window 2024版笔记 下载 安装 操作 配置

---Docker 前言--- Docker windows版官方版是一款专业开源的应用容器引擎&#xff0c;可以加快用户构建、共享和运行现代应用程序的速度&#xff0c;支持运行Linux和Windows Docker容器。 Docker 在容器的基础上&#xff0c;进行了进一步的封装&#xff0c;从文件系统、网络互…

关于Windows Media Player的一些知识,看这篇文章就差不多了

你知道如何在电脑上打开Windows Media Player吗?如果它不是你电脑上默认的媒体播放器,你知道如何将其设为默认吗?此外,如果你找不到它,你知道怎么把它找回来吗?这篇文章将向你展示你想要了解的所有信息。 在这篇文章中,我们将向你展示以下信息: 如何打开Windows Medi…

从傅立叶变换到奥运五环

傅立叶变换的本质 离散傅立叶变换的本质就是用一系列的正弦&#xff08;或者余弦&#xff09;函数的和来拟合一个周期函数f(t)。公式如下&#xff1a; (1) 其中T是f(t)的周期&#xff0c;即f(tT)f(t)对任意t成立。和的周期是。换句话说&#xff0c;后两者的频率是f(t)的频率的…

推荐10个最受欢迎的 Vue.js UI 库

在2024年,随着Vue.js的不断普及和发展,这个轻量级、易于学习的JavaScript框架在前端开发者中的受欢迎程度日益上升。Vue.js之所以受到青睐,很大一部分原因是其庞大的生态系统,特别是众多的UI库,这些库提供了预先构建的组件和工具,帮助开发者快速高效地构建出既美观又响应…

Python算法深度探索:从基础到进阶

引言 本文将引导您从Python的基础算法出发&#xff0c;逐步深入到更复杂的算法领域。我们将探讨数组操作、图算法以及机器学习中的常用算法&#xff0c;并通过实例和代码展示它们在实际应用中的价值。 1. 基础算法&#xff1a;数组操作 数组操作是算法实现中非常基础且重要的一…

Editing While Playing 使用 Easyx 开发的 RPG 地图编辑器 tilemap eaitor

AWSD移动画布 鼠标右键长按拖拽 鼠标左键长按绘制 可以边拖拽边移动画布边绘制。 F1 导出 DLC F2 导入DLC author: 民用级脑的研发记录 1309602336qq.com 开发环境&#xff1a; 内置 easyx 的 devc 5.11 或者 VS 2022 TDM GCC 4.9.2 64-bit c11及以上都可运行 windows 环境运行…

算法-16-并查集

并查集简介 并查集&#xff1a;一开始&#xff0c;把a&#xff0c;b&#xff0c;c放入并查集&#xff0c;a自己一个集合&#xff0c;b自己一个&#xff0c;c自己一个 提供的方法 1.boolean isSameSet(a,b)&#xff0c;判断ab是否在同一个集合 2.void union(a,b),把a所…

Hadoop-Yarn-ResourceManagerHA

在这里先给屏幕面前的你送上祝福&#xff0c;祝你在未来一年&#xff1a;技术步步高升、薪资节节攀升&#xff0c;身体健健康康&#xff0c;家庭和和美美。 一、介绍 在Hadoop2.4之前&#xff0c;ResourceManager是YARN集群中的单点故障 ResourceManager HA是通过 Active/St…

163基于matlab的不同目标函数的盲源信号分离基于负熵的

基于matlab的不同目标函数的盲源信号分离基于负熵的&#xff1b;基于负熵的改进算法&#xff1b; 基于峭度的&#xff1b;基于互信息的&#xff1b;基于非线性PCA的。输出解混前后信号结果。程序已调通&#xff0c;可直接运行。 163 负熵、峭度、互信息、PCA 信号处理 (xiaohon…

牛客——递归实现组合型枚举(枚举,dfs)

链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 来源&#xff1a;牛客网 题目描述 从 1~n 这 n 个整数中随机选出 m 个&#xff0c;输出所有可能的选择方案。n>0n \gt 0n>0, 0≤m≤n0 \leq m \leq n0≤m≤n, n(n−m)≤25n(n-m)\leq 25n(n−m)≤25。 输入描述…

LeetCode Python - 17.电话号码的字母组合

目录 题目答案运行结果 题目 给定一个仅包含数字 2-9 的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意 1 不对应任何字母。 示例 1&#xff1a; 输入&#xff1a;digits…

HGAME 2024 WEEK2 Web方向题解 全

---------【WEEK-2】--------- What the cow say? 题目描述&#xff1a;the cow want to tell you something 注意title&#xff0c;Python的flask漏洞可多呢 版本310 先测一下SSTI 正常情况下 SSTI测试 变量渲染测试&#xff0c;被waf了&#xff0c;说明方向对了 单单过滤…

企业人力资源大数据分析解决方案

一、 背景痛点 随着企业发展和市场竞争的加剧,传统的人力资源管理模式已经无法满足企业的需求。而大数据技术的出现,为企业提供了新的解决方案,能够更好地应对市场变化和人力资源挑战。 二、基本人力分析应用 整个人力资源体系是承接集团战略的重要部分,通过对人力资源战…

《小强升职记:时间管理故事书》阅读笔记

目录 前言 一、你的时间都去哪儿了 1.1 你真的很忙吗 1.2 如何记录和分析时间日志 1.3 如何找到自己的价值观 二、无压工作法 2.1 传说中的“四象限法则 2.2 衣柜整理法 三、行动时遇到问题怎么办&#xff1f; 3.1 臣服与拖延 3.2 如何做到要事第一&#xff1f; 3.…