解密Redis:应对面试中的缓存相关问题

news2025/1/9 0:12:16

文章目录

    • 1. 缓存穿透问题及解决方案
    • 2. 缓存击穿问题及解决方案
    • 3. 缓存雪崩问题及解决方案
    • 4. Redis的数据持久化
    • 5. Redis的过期删除策略和数据淘汰策略
    • 6. Redis分布式锁和主从同步
    • 7. Redis集群方案
    • 8. Redis的数据一致性保障和高可用性方案

在这里插入图片描述

导语: 在面试过程中,面试官可能会问到关于Redis缓存的一系列问题。本文将深入探讨Redis缓存相关面试题,并为你提供详细的解答,帮助你在面试中游刃有余。

在这里插入图片描述

1. 缓存穿透问题及解决方案

面试官: 什么是缓存穿透?该如何解决?

候选人: 缓存穿透是指查询一个一定不存在的数据,在存储层查不到数据时,不写入缓存。这导致每次请求都需要去数据库查询,可能会造成数据库崩溃。通常这种情况是遭到攻击。

解决方案: 解决缓存穿透问题通常采用布隆过滤器。布隆过滤器是用于检索一个元素是否在一个集合中的数据结构。我们可以使用Redisson实现的布隆过滤器。它在底层使用一个比较大的数组,用二进制的0或1来存储元素的存在状态。通过多次哈希计算,确定元素的位置并将相应位置的值置为1。查询时也是类似的过程。

然而,布隆过滤器有一定的误判率,我们可以通过设置误判率来平衡性能和准确性,通常不会超过5%。

2. 缓存击穿问题及解决方案

面试官: 什么是缓存击穿?该如何解决?

候选人: 缓存击穿是指设置了过期时间的缓存key,在某一时刻同时失效,导致大量请求直接转发到数据库,可能会压垮数据库。

解决方案: 缓解缓存击穿问题的方式有两种:

  1. 互斥锁: 当缓存失效时,不立即去数据库加载数据,而是先使用例如Redis的setnx命令设置一个互斥锁。操作成功返回时再进行数据库加载并写入缓存,否则重试获取缓存的方法。

  2. 设置当前key逻辑过期: 在设置缓存时,同时设置一个过期时间字段存入缓存,而不给当前key设置过期时间。当查询时,先从缓存中取出数据后,判断时间是否过期。如果过期,则开启另一个线程进行数据同步,当前线程正常返回数据,尽管数据不是最新的。

两种方案各有优劣,如果需要强一致性,建议使用互斥锁,虽然性能可能较差,但避免了脏数据和死锁问题。如果对数据的实时性要求不高,可以采用第二种方案来保证高可用性和较好的性能。

3. 缓存雪崩问题及解决方案

面试官: 什么是缓存雪崩?该如何解决?

候选人: 缓存雪崩指的是设置缓存时采用了相同的过期时间,导致多个缓存在某一时刻同时失效,大量请求转发到数据库,使数据库瞬时压力过重,引起性能问题。

解决方案: 缓解缓存雪崩问题的方法是将缓存的过期时间分散开,例如在原有的过期时间基础上增加一个随机值,使每个缓存的过期时间不完全一致,降低缓存失效的重复率,从而减少集体失效事件的发生。

4. Redis的数据持久化

面试官: Redis的数据持久化方式有哪些?

候选人: Redis提供了两种数据持久化方式:RDB和AOF。

  1. RDB(Redis Database): 它是一个快照文件,将Redis内存中存储的数据写入磁盘。当Redis实例宕机需要恢复数据时,可以从RDB的快照文件中恢复数据。

  2. AOF(Append-Only File): 它是一个追加文件,在AOF模式下,当Redis执行写命令时,会将写命令以日志的形式追加到AOF文件中。当Redis实例宕机需要恢复数据时,会通过重新执行AOF文件中记录的命令来恢复数据。

面试官: RDB和AOF两种持久化方式有什么区别?

候选人: RDB和AOF两种持久化方式有以下区别:

  1. 数据格式: RDB以二进制格式保存数据,文件较小,恢复速度较快;AOF以文本形式保存数据,文件较大,恢复速度较慢。

  2. 恢复速度: RDB恢复速度相对较快,因为数据是以二进制格式保存在磁盘上,读取速度快;而AOF恢复速度较慢,因为需要逐行解析AOF文件中的命令。

  3. 数据安全性: RDB的数据可能存在较小的数据丢失风险,因为RDB采用快照方式保存数据,如果Redis在保存RDB文件时宕机,可能会丢失最后一次快照之后的数据;而AOF可以通过配置不同的fsync策略来保证数据安全性,可以选择每条写命令都立即刷入磁盘(效率较低),或者定期刷入磁盘(效率较高但会增加数据丢失风险)。

  4. 持久化机制: RDB是定时触发的,可以通过配置定期执行快照操作,或在满足一定条件时执行快照;而AOF是在每次写操作执行时都会追加到AOF文件中,实时记录数据变化。

通常情况下,可以同时开启RDB和AOF两种持久化方式,以提高数据的安全性和恢复效率。

5. Redis的过期删除策略和数据淘汰策略

面试官: Redis的过期删除策略有哪些?

候选人: Redis的过期删除策略包括惰性删除和定期删除两种方式。

  1. 惰性删除: 在设置了过期时间的key被访问时,会先判断该key是否过期,如果过期则删除;如果未过期,则返回数据。这种方式在获取数据时判断是否过期,如果过期就删除,是一种延迟删除的方式。

  2. 定期删除: Redis会以一定频率执行检查操作,定期扫描所有key,删除已过期的key。定期删除的两种模式为SLOW模式和FAST模式,前者是定时任务,执行频率默认为10hz,每次不超过25ms,可以通过修改配置文件redis.conf的hz选项调整;后者执行频率不固定,每次事件循环会尝试执行,但两次间隔不低于2ms,每次耗时不超过1ms。

面试官: Redis的数据淘汰策略有哪些?

候选人: Redis的数据淘汰策略包括LRU(最近最少使用)和LFU(最少频率使用)两种方式。

  1. LRU(最近最少使用): 根据key的最近访问时间判断,删除最近最少使用的key。

  2. LFU(最少频率使用): 统计每个key的访问频率,删除访问频率最低的key。

在Redis中可以通过设置相关配置来选择不同的数据淘汰策略,默认是noeviction,即不删除任何数据。选择LRU和LFU策略时,需要注意性能和数据一致性的权衡。

6. Redis分布式锁和主从同步

面试官: Redis分布式锁如何实现?

候选人: Redis分布式锁的实现主要依赖于Redis的setnx(SET if not exists)命令。由于Redis是单线程的,在使用setnx命令时,只有一个客户端能够成功设置某个key的值,其他客户端会被拒绝。通过这一特性,我们可以使用setnx命令来实现分布式锁。

面试官: 那如何控制Redis实现分布式锁的有效时长呢?

候选人: setnx命令本身并不能控制锁的有效时长。为了解决这个问题,我们可以使用Redisson等Redis的客户端框架来实现分布式锁。这些框架允许手动加锁,并且可以控制锁的失效时间和等待时间。

在Redisson中,我们可以使用锁的lock()方法来手动加锁,通过设置锁的失效时间来控制锁的有效时长。同时,Redisson还提供了看门狗机制,用于检查当前线程是否持有锁,并在合适的时机更新锁的失效时间,从而避免锁的过期。

面试官: Redis分布式锁是可重入的吗?

候选人: 是的,Redis分布式锁是可重入的。在内部实现中,分布式锁会使用类似计数器的方式来实现可重入。当一个线程获取锁时,会增加计数,释放锁时会减少计数。如果同一个线程再次获取锁,会判断是否是当前线程持有的锁,如果是,则增加计数。当计数归零时,锁会被完全释放。

面试官: Redisson实现的分布式锁能解决主从一致性的问题吗?

候选人: Redisson实现的分布式锁不能解决主从一致性问题。例如,当一个线程在主节点上成功加锁后,数据会异步复制到从节点。此时,如果主节点宕机,从节点可能会被提升为新的主节点,而现在来了一个新的线程,再次加锁,就会在新的主节点上成功加锁。这样就导致了两个节点同时持有同一把锁的问题。

为了解决主从一致性问题,可以使用Redisson提供的红锁(RedLock)机制。红锁要求在多个Redis节点上创建锁,并且在大多数节点上成功创建锁,以确保锁的一致性。但是红锁会增加锁的获取复杂性和运维维护成本,并且在高并发场景下性能较差,因此在实际项目中使用较少,甚至官方也废弃了红锁。

面试官: 如果业务需要保证数据的强一致性,你会采取什么样的措施?

候选人: 如果业务需要保证数据的强一致性,Redis本身是无法满足的,因为为了保证强一致性,必然会影响性能。在这种情况下,可以考虑使用其他分布式锁机制,例如ZooKeeper实现的分布式锁。ZooKeeper可以保证强一致性,但相应地增加了运维成本和性能开销。

7. Redis集群方案

面试官: Redis集群有哪些方案?

候选人: Redis提供了三种集群方案:主从复制、哨兵模式和Redis分片集群。

  1. 主从复制: 主从复制是指一个主节点同步数据到多个从节点的过程。主节点负责写入数据,从节点负责读取数据。当主节点写入数据时,会将数据异步复制到从节点,从节点定时拉取数据。主从复制实现了读写分离,提高了Redis的并发能力和读取性能。

  2. 哨兵模式: 哨兵模式是用于实现高可用性的方案。在哨兵模式中,有多个Redis实例,其中一个为主节点,其他为从节点。同时有一个哨兵进程监控所有节点的状态,当主节点宕机时,哨兵会自动将某个从节点升级为主节点,保证服务的可用性。

  3. Redis分片集群: Redis分片集群是将数据分片存储在多个Redis实例中,实现数据的水平分割。每个实例负责处理其中的一部分数据,从而提高Redis的存储和处理能力。在分片集群中,每个实例都是独立的,没有主从之分。

面试官: 那你来介绍一下主从同步的流程。

候选人: 主从同步分为全量同步和增量同步两个阶段。

  1. 全量同步: 当从节点与主节点第一次建立连接时,会进行全量同步。流程如下:

    • 从节点请求主节点进行数据同步,并携带自己的复制ID(replication ID)和复制偏移量(offset)。

    • 主节点判断是否是从节点的第一次请求,主要判断依据是判断从节点的复制ID是否与主节点一致。如果不一致,则认为是第一次同步请求,主节点会发送自己的复制ID和复制偏移量给从节点,让从节点与主节点的信息保持一致。

    • 同时,主节点执行bgsave命令生成RDB文件,并发送给从节点执行。从节点在执行RDB文件时,先清空自己的数据,然后按照主节点发送的RDB文件来恢复数据。这样,主从之间的数据就保持了一致。

    • 在全量同步期间,如果有新的写命令到达主节点,主节点会记录这些写命令到缓冲区,缓冲区是一个日志文件。当全量同步完成后,主节点会将缓冲区的日志文件发送给从节点,从节点执行这些写命令来同步数据。

  2. 增量同步: 全量同步完成后,从节点与主节点之间的数据就保持了一致。此后,主节点会将新的写命令以增量方式发送给从节点,从节点执行这些增量命令来保持数据的同步。

面试官: Redis分布式集群中如何处理数据分片和读写操作?

候选人: 在Redis分布式集群中,数据分片是将数据分散存储在多个Redis实例中的过程。通过哈希算法,将相同的key映射到同一个实例中,实现数据的水平分割。

对于读写操作,Redis分片集群使用了一种代理方式来实现:

  • 对于写操作,客户端将写请求发送给集群的其中一个实例,该实例会根据哈希算法找到负责该key的实例,并将写命令发送给该实例,实现数据的写入。

  • 对于读操作,客户端将读请求发送给集群的其中一个实例,该实例会根据哈希算法找到负责该key的实例,并将读命令发送给该实例,获取数据。

通过数据分片和读写代理,Redis分片集群可以实现数据的均衡存储和负载均衡,提高了数据的处理能力和读写性能。

8. Redis的数据一致性保障和高可用性方案

面试官: Redis的数据一致性如何保障?

候选人: Redis的数据一致性在主从复制和哨兵模式下,由Redis本身提供的复制机制保障。当主节点写入数据时,会将数据异步复制到从节点,确保数据的一致性。在哨兵模式中,哨兵进程会监控主从节点的状态,当主节点宕机时,会自动将某个从节点升级为新的主节点,保证数据的连续性。

然而,对于分片集群来说,数据一致性需要由应用程序来保障。在分片集群中,由于数据被分散存储在多个实例中,每个实例负责处理其中的一部分数据,因此数据的一致性需要应用程序自行处理。一般情况下,可以通过以下方式来保障数据的一致性:

  1. 使用分布式事务: 在涉及到多个Redis实例的写操作时,可以使用分布式事务来保障数据的一致性。一种常见的实现方式是使用分布式事务管理器,如XATCC,将多个Redis实例的写操作组织成一个事务,要么全部成功,要么全部失败,从而保证数据的一致性。

  2. 引入数据同步机制: 应用程序可以自行实现数据同步机制,例如在写入数据时,同时将数据写入多个Redis实例,并使用消息队列等方式进行数据同步,以保证数据在多个实例之间的一致性。

面试官: Redis的高可用性方案有哪些?

候选人: Redis的高可用性主要通过哨兵模式和Redis集群来实现。

  1. 哨兵模式: 哨兵模式是用于实现Redis高可用的方案。在哨兵模式中,有多个Redis实例,其中一个为主节点,其他为从节点。同时有一个哨兵进程监控所有节点的状态,当主节点宕机时,哨兵会自动将某个从节点升级为主节点,保证服务的可用性。哨兵模式实现了自动故障转移,提高了Redis的高可用性。

  2. Redis集群: Redis集群是另一种实现Redis高可用的方式。在Redis集群中,数据被分片存储在多个Redis实例中,每个实例负责处理其中的一部分数据,从而提高了Redis的存储和处理能力。当部分实例宕机时,集群仍然可以继续提供服务,保障了系统的高可用性。

面试官: Redis的数据持久化方式有哪些?它们有什么区别?

候选人: Redis的数据持久化方式有两种:RDB(Redis Database)和AOF(Append Only File)。

  1. RDB: RDB是Redis的一种快照持久化方式。当启用RDB持久化时,Redis会周期性地将内存中的数据生成一个快照文件(dump.rdb),该文件是二进制格式的,包含了当前数据库中的所有键值对数据。RDB持久化的优点是快速、紧凑,适合用于备份数据和全量恢复。缺点是如果Redis意外宕机,可能会丢失最后一次持久化后的数据。

  2. AOF: AOF是Redis的另一种持久化方式。当启用AOF持久化时,Redis会将写命令追加到AOF文件中,记录了数据写操作的命令序列。AOF持久化的优点是可以保证更高的数据安全性,因为它记录了写操作的命令序列,只要重放这些命令,就能完整恢复数据。缺点是相比RDB,AOF文件体积较大,并且在数据恢复时,AOF文件的重放可能比RDB的加载更慢。

面试官: 这两种持久化方式中,哪一种恢复速度比较快呢?

候选人: RDB持久化方式恢复速度比较快。由于RDB文件是二进制格式的,并且在保存时经过压缩处理,所以文件体积较小。在恢复数据时,Redis只需加载RDB文件,将其中的数据读入内存,速度相对较快。

AOF持久化方式恢复数据时,需要重放AOF文件中的写操作命令,这个过程相对于RDB的加载来说,可能会慢一些。但是AOF可以保证更高的数据安全性,因为它记录了完整的写操作序列,避免了数据丢失的风险。

面试官: Redis的过期策略有哪些?

候选人: 在Redis中,有两种数据过期删除策略:

  1. 惰性删除(lazy expiration): 在设置了过期时间的key被访问时,会先检查该key是否过期,如果过期,则会立即删除;如果没有过期,则返回该key的值。这种策略称为惰性删除,因为Redis并不主动删除过期的key,而是等待访问时才删除。

  2. 定期删除(定时任务删除): Redis会以一定的频率(默认为每秒钟10次)检查部分设置了过期时间的key,将过期的key删除。这种策略称为定期删除,因为Redis定期地进行key的过期检查和删除操作。

这两种过期策略是配合使用的,Redis会根据需要对过期key进行惰性删除和定期删除,以保证数据的有效过期。

面试官: Redis的数据淘汰策略有哪些?

候选人: Redis中的数据淘汰策略用于在内存不足时,选择哪些数据被删除,从而释放内存空间。Redis提供了多种数据淘汰策略,常见的有以下几种:

  1. volatile-lru(LRU算法): 这是Redis的默认数据淘汰策略。在设置了过期时间的key中,Redis会优先淘汰最近最少使用的数据(LRU算法),即那些最近被访问较少的数据。这样可以保留那些经常被访问的热点数据,提高缓存命中率。

  2. allkeys-lru(LRU算法): 这种策略是在所有的key中进行LRU算法淘汰,不仅包括设置了过期时间的key,还包括没有设置过期时间的key。这样可以使得Redis保持最新的数据,但是会增加内存压力。

  3. volatile-ttl(TTL算法): 在设置了过期时间的key中,Redis会优先淘汰剩余存活时间较短的数据(TTL算法)。这样做可以确保即将过期的数据被优先淘汰,从而避免存活时间很长但已经不再使用的数据占用内存。

  4. volatile-random: 在设置了过期时间的key中,Redis会随机选择一部分数据进行淘汰。这种策略适用于对所有缓存数据的存活时间没有特别要求的情况。

  5. allkeys-random: 这种策略是在所有的key中进行随机淘汰。类似于volatile-random,适用于对所有缓存数据的存活时间没有特别要求的情况。

除了以上几种淘汰策略,Redis还提供了volatile-lfu(LFU算法,最少使用频率)和allkeys-lfu(LFU算法)等淘汰策略,可以根据业务需求选择合适的策略。

面试官: Redis如何实现分布式锁?

候选人: Redis实现分布式锁的常见方式是利用SETNX命令(SET if Not eXists)。由于Redis是单线程的,使用SETNX命令可以保证在同一时刻只有一个客户端能够成功地设置某个键的值,从而实现锁的效果。

具体实现步骤如下:

  1. 客户端尝试通过SETNX命令设置一个特定的键,该键的值为一个唯一标识(例如,可以使用UUID)。

  2. 如果SETNX命令返回1,表示键设置成功,客户端获取到了锁。

  3. 如果SETNX命令返回0,表示键已经存在,其他客户端已经持有了锁,当前客户端获取锁失败。

  4. 当客户端执行完业务操作后,通过DEL命令释放锁,将键从Redis中删除。

需要注意的是,为了防止死锁,获取锁的客户端在执行完业务操作后,应该及时释放锁。同时,为了防止误删除其他客户端持有的锁,需要在释放锁时校验锁的标识,确保只有持有正确标识的锁才被删除。

面试官: Redis分布式锁有没有什么问题?

候选人: 是的,Redis分布式锁虽然简单高效,但也有一些问题需要注意:

  1. 死锁问题: 如果一个持有锁的客户端在执行业务操作时发生了异常导致未释放锁,就会出现死锁问题。为了避免死锁,需要在获取锁后设置锁的过期时间,确保即使锁没有被释放,也会在一定时间后自动释放,防止长期占用锁。

  2. 误删问题: 由于分布式锁是通过设置特定的键值对来实现的,当客户端释放锁时,可能会误删其他客户端持有的锁。为了避免误删问题,可以为每个客户端设置一个唯一的锁标识,释放锁时校验标识确保只删除自己持有的锁。

  3. 锁竞争问题: 在高并发情况下,多个客户端可能同时竞争一个锁,这会导致锁的频繁竞争和释放,影响性能。为了减少锁竞争问题,可以使用带有重试机制的获取锁操作,避免因竞争失败而频繁重试。

面试官: 很好,你对Redis相关面试题回答得很不错。有没有什么问题想要问我的?

候选人: 是的,我想了解贵公司在使用Redis时,最常见的应用场景和面临的挑战是什么?

面试官: 很好的问题!在我们公司,最常见的Redis应用场景包括缓存加速、会话存储、计数器和分布式锁等。我们利用Redis的高速读写能力,将一些频繁读写的数据存储在Redis缓存中,提高系统的性能和响应速度。同时,我们也使用Redis来存储用户会话信息,实现无状态的会话管理,从而方便水平扩展。

在面对Redis的挑战时,主要集中在数据一致性、高可用性和性能方面。为了保障数据的一致性,我们在使用Redis时会结合其他组件或方案来实现分布式锁和数据同步。例如,在使用Redis作为缓存时,我们会考虑缓存与数据库之间的数据同步,以保证数据的一致性。在高并发的情况下,缓存雪崩和缓存击穿是常见的问题,我们需要采取相应的缓解措施,如设置合理的缓存过期时间和使用热点数据预热等。

另外,高可用性也是一个重要的挑战。为了避免单点故障,我们通常会部署Redis的主从复制或使用Redis集群来实现高可用性。在Redis主从复制中,需要注意主节点故障时的故障转移和从节点数据同步的问题。

此外,性能优化也是我们关注的重点。在使用Redis时,我们需要细心设计缓存数据结构、选择合适的淘汰策略和配置合理的持久化方式,以及合理利用Redis的数据结构和命令来优化性能。

面试官: 你对Redis的应用场景和挑战有了很好的理解。还有其他问题需要咨询吗?

候选人: 是的,我想了解一下贵公司对于技术人才的培养和发展计划。

面试官: 很好的问题!在我们公司,我们非常重视技术人才的培养和发展。我们鼓励员工不断学习和探索新技术,提供丰富的培训和学习资源。我们会定期组织内部技术分享会,让员工有机会分享自己的技术经验和成果。

同时,我们也会根据员工的兴趣和擅长领域,提供个性化的发展计划,帮助员工在自己擅长的领域深耕,并在技术职业道路上不断成长。我们鼓励员工参与开源项目和技术社区,扩展技术视野,与更多的优秀技术人才交流合作。

另外,我们公司也提供良好的晋升机制和职业发展通道。优秀的技术人才有机会晋升为技术专家或技术经理,并参与更具挑战性和复杂的项目,为公司的技术发展贡献更多力量。

面试官: 感谢你的提问!我们非常看重员工的成长和发展,希望员工能在公司里得到充分的锻炼和发展。如果没有其他问题,我们就结束本次面试。

候选人: 非常感谢您的时间和机会,我对贵公司的工作环境和发展前景充满期待。如果有进一步的消息,我会及时跟进。再次感谢!

面试官: 非常感谢你的参与和回答,希望你能尽快收到面试结果。祝你好运!

以上就是对Redis相关面试题的整理和回答,希望对你有所帮助。在面试时,展现自己的知识和技能是非常重要的,同时也要表现出自信和积极的态度。祝你面试顺利,取得理想的工作成果!

在这里插入图片描述

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

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

相关文章

社区说|Flutter 一知半解,带你拨云见月

Hello,大家好,我是 Flutter GDE 郭树煜,今天的主题是科普向的分享内容,主要是带大家更全面的去理解 Flutter ,尽可能帮助大家破除一些误解,分享内容不会特别长,但是应该会帮助你从新认识下 Flut…

C++源码使用make生成动态库和静态库

我这个新电脑,没装Homebrew,把这个复制进终端安装。 /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" 下载过程如下所示

blender凹凸感和置换形变

一、怎么做出凹凸感 需要三个部分的内容: 1、一个基础的纹理:告诉计算机需要用一个什么样的纹理做凹凸,纹理一般采用黑白,在计算机里面,从 0 - 1之间的值可以用从黑到白之间不同的灰度来表示因此,有一张黑白…

char类型到底是有符号还是无符号的?

最近在整理代码时,发现有一些如下类型的警告: ..\XXXXX\XXXXX.c(224): warning: #186-D: pointless comparison of unsigned integer with zero 这个警告的意思是无符号数与0比较是无意义,而我报警告的代码行如下: char len_v…

阿里用户序列建模ETA

End-to-End User Behavior Retrieval in Click-Through Rate Prediction Model 摘要 现实很少有工作可以处理长序列用户建模的问题,SIM提出了两阶段方法。第一阶段,辅助任务旨在从长序列用户行为检索最相关的用户行为序列。第二阶段,经典的…

位图和 DC 有什么特别之处?

相信设备上下文 (DC, Device Context) 对你来说,应该很熟悉。 基本工作方式是,你可以通过调用 SelectObject 来将画笔(Pen),画刷(Brush),字体(Font)和位图(Bitmap)等这些对象选入设备上下文中,但是,这里的位…

Android 面试题 应用程序结构 十一

🔥 Framework主要包含以下模块 🔥 ActivityManagerService 这是一个Activity的管理者,负责管理所有Activity的生命周期。WindowManagerService 它是手机屏幕的的管理者,管理着屏幕的详细情况,所有对屏幕的操作最终都…

ChatGPT学python——制作自己的AI模型(一)初步了解

前言 「作者主页」:雪碧有白泡泡 「个人网站」:雪碧的个人网站 「推荐专栏」: ★java一站式服务 ★ ★前端炫酷代码分享 ★ ★ uniapp-从构建到提升★ ★ 从0到英雄,vue成神之路★ ★ 解决算法,一个专栏就够了★ ★ 架…

2023国际先进制造青年科学家大会圆满结束!易知微受邀进行数字孪生主题报告分享

2023年7月30日,以“新青年,新视野,新制造”为主题的2023国际先进制造青年科学家大会在浙江绍兴开幕,旨在强力推进创新深化改革攻坚开放提升,进一步做强“人才+产业”双联驱动、人才集聚与产业发展共振同兴&…

NLP/CV相关模型库-阿里

模型库地址:https://www.modelscope.cn/models

30岁转行学编程,更容易成功

“男人30而立,我没有退路,只有选择勇往直前,这样我才能无所畏惧,因为我希望在我的人生篇章里,能拥有浓墨重彩的一笔!” 30岁,在经历一番“打击”后毅然决然选择学编程,为家人也为自…

解决Mysql报错2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)

1.找到mysql文件夹,将my,ini文件放入bin文件夹 2.管理员模式打开cmd 3.输入netstat -ano查看端口占用情况,这里我已经开启mysql应用,所以会有3306,如果没有开启是不会有的 4.输入sc delete mysql,删除mysql服务 5.将…

Vue如何实现重定向

在刚登录之后,我们想要默认展示一下用户登录,这个功能如何实现: 就是重定向为/home/user这个值 我们就是在/home 上加一个重定向 具体怎么做那,先找到/home的路由规则 想要实现重定向,增加一个redirect就行

基于SpringBoot+Vue的广场舞团管理系统设计与实现(源码+LW+部署文档等)

博主介绍: 大家好,我是一名在Java圈混迹十余年的程序员,精通Java编程语言,同时也熟练掌握微信小程序、Python和Android等技术,能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

无涯教程-Lua - 环境安装

在Windows上安装 为Windows环境开发了一个单独的名为" SciTE"的IDE,可以从https://code.google.com/p/luaforwindows/下载部分。 运行下载的可执行文件以安装Lua IDE。 由于它是一个IDE,因此您可以使用它来创建和构建Lua代码。 如果您有兴趣在命令行模…

【私藏】matlab踏实手把手常规练习附全套学习资料

目录 前言 福利&#xff1a;文末有matlab全套资料哦 01分段函数 02复合图 ⚪️ 两个一元函数yx^3-x-1和y|x|^(0.2)sin(5x)在区间-1<2的复合图。函数与图像<> 03三维平面图 ⚪️ 三维平面图使用mesh绘制网格图&#xff0c;surf绘制三维曲面图&#xff0c;使用…

filebeat kibana elasticsearch 日志监控

解压三个压缩包 一、filebeat的安装部署 1、打开filebeat的配置文件 2、Filebeat inputs 处打开日志输入开关&#xff0c;设置要监控的路径 3、Outputs 输出中设置Elasticsearch output的输出地址 4、执行 ./filebeat & 二、Elasticsearch 安装部署 1、修改配置文件 …

C语言:相交链表

Lei宝啊&#xff1a;个人主页 愿美好与我们不期而遇 题目&#xff1a; 描述 给你两个单链表的头节点 headA和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&#xff0c;返回 null 接口 struct ListNode *getIntersectionNode (str…

使用javax.validation.constraints进行数据验证

使用javax.validation.constraints进行数据验证 在Java应用中&#xff0c;数据的验证是一个很重要的部分&#xff0c;特别是在接收用户输入或处理外部数据时。为了简化和标准化数据验证的过程&#xff0c;Java提供了javax.validation.constraints包&#xff0c;其中包含一系列注…

MySQL数据库——约束

文章目录 前言主键约束创建主键单列主键联合主键通过修改表结构来指定主键 删除主键约束 自增主键约束创建自增主键 非空约束创建非空约束删除非空约束 唯一约束创建唯一约束删除唯一性约束 默认约束创建默认约束删除默认约束&#xff08;改为null为默认值&#xff09; 零填充约…