【面试题----缓存】

1.Redis和Memcached的异同。

Memcached

  1. 可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS;
  2. 只支持简单的key/value数据结构,不像Redis可以支持丰富的数据类型。
  3. 无法进行持久化,数据不能备份,只能用于缓存使用,且重启后数据全部丢失。
  4. 无法进行数据同步,不能将MC中的数据迁移到其他MC实例中。
  5. Memcached内存分配采用Slab Allocation机制管理内存,value大小分布差异较大时会造成内存利用率降低, 并引发低利用率时依然出现踢出等问题。需要用户注重value设计。

Redis

  1. 支持多种数据结构,如string、 list、hash、set、zset等;
  2. 支持持久化操作,可以进行aof及rdb数据持久化到磁盘,从而进行数据备份或数据恢复等操作,较好的防止数据丢失的手段;
  3. 支持通过Replication进行数据复制,通过master-slave机制,可以实时进行数据的同步复制来实现HA;
  4. 单线程请求,所有命令串行执行,并发情况下不需要考虑数据一致性问题,但性能受限于CPU性能,故单实例CPU最高才可能达到5-6wQPS每秒;
  5. 支持pub/sub消息订阅机制,可以用来进行消息订阅与通知;
  6. Redis在string类型上会消耗较多内存,可以使用hash表压缩存储以降低内存耗用。

 

2.Redis作为分布式缓存可能会存在哪些问题,怎么解决?

  • 缓存穿透预防及优化:缓存穿透是指查询一个根本不存在的数据,缓存层和存储层都不会命中;缓存穿透将导致不存在的数据每次请求都要到存储层去查询,失去了缓存保护后端存储的意义;解决方法:缓存空对象和布隆过滤器拦截;
  • 缓存雪崩问题优化:由于缓存层承载着大量请求,有效的保护了存储层,但是如果缓存层由于某些原因整体不能提供服务,于是所有的请求都会达到存储层,存储层的调用量会暴增,造成存储层也会挂掉的情况;预防和解决缓存雪崩问题,可以从以下三个方面进行着手:保证缓存层服务高可用性、依赖隔离组件为后端限流并降级、提前演练。
  • 缓存热点key重建优化:开发人员使用缓存和过期时间的策略既可以加速数据读写,又保证数据的定期更新,这种模式基本能够满足绝大部分需求。但如果热点Key和重建缓存耗时两个问题同时出现,可能就会对应用造成致命的危害;解决方法:互斥锁(只允许一个线程重建缓存)、永远不过期(唯一不足的就是重构缓存期间会出现数据不一致的情况)。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一些可能的 Mybatis-plus 面试题: 1. 什么是 Mybatis-plus? Mybatis-plus 是基于 Mybatis 的增强工具,简化了 Mybatis 的开发流程,提供了许多方便的功能,如自动生成代码、注解支持、通用 CRUD 操作等。 2. Mybatis-plus 的优势是什么? Mybatis-plus 有以下优势: - 简化开发流程,提高开发效率。 - 提供了许多方便的功能,如自动生成代码、注解支持、通用 CRUD 操作等。 - 提供了一些实用的插件,如分页插件、性能分析插件等。 - 支持 Lambda 表达式,可以更方便地编写条件查询。 3. Mybatis-plus 的架构是什么样的? Mybatis-plus 的架构包括以下组件: - Entity:实体类,对应数据库中的表。 - Mapper:数据访问层,与数据库交互的接口。 - Service:业务逻辑层,处理业务逻辑。 - Controller:控制层,接收请求并调用 Service 处理请求。 4. Mybatis-plus 的注解有哪些? Mybatis-plus 支持以下注解: - @TableName:指定实体类对应的数据库表名。 - @TableId:指定实体类的主键属性。 - @TableField:指定实体类属性对应的数据库列名。 - @Version:指定实体类的乐观锁属性。 5. Mybatis-plus 如何实现分页查询? Mybatis-plus 提供了一个分页插件,可以方便地实现分页查询。具体实现步骤如下: - 添加分页插件依赖。 - 在 Mybatis 配置文件中配置分页插件。 - 在 Mapper 接口中添加查询方法,并使用 Page 类作为参数。 - 在 Service 层中调用 Mapper 接口的查询方法,传入 Page 对象。 6. Mybatis-plus 如何实现条件查询? Mybatis-plus 支持 Lambda 表达式,可以更方便地编写条件查询。具体实现步骤如下: - 在实体类中定义查询条件属性。 - 在 Mapper 接口中添加查询方法,并使用 LambdaQueryWrapper 类构建查询条件。 - 在 Service 层中调用 Mapper 接口的查询方法,传入 LambdaQueryWrapper 对象。 7. Mybatis-plus 如何实现自动生成代码? Mybatis-plus 提供了一个代码生成器,可以方便地生成 Entity、Mapper、Service 和 Controller 等代码。具体实现步骤如下: - 添加代码生成器依赖。 - 在配置文件中配置代码生成器相关信息。 - 运行代码生成器,生成代码。 8. Mybatis-plus 如何实现多表关联查询? Mybatis-plus 支持多表关联查询,可以使用 JoinWrapper 类进行关联查询。具体实现步骤如下: - 在 Mapper 接口中添加查询方法,并使用 JoinWrapper 类构建关联查询条件。 - 在 Service 层中调用 Mapper 接口的查询方法,传入 JoinWrapper 对象。 9. Mybatis-plus 如何实现乐观锁? Mybatis-plus 支持乐观锁,可以使用 @Version 注解指定乐观锁属性。具体实现步骤如下: - 在实体类中添加 @Version 注解。 - 在 Mapper 接口中添加更新方法,使用 UpdateWrapper 类构建更新条件。 - 在 Service 层中调用 Mapper 接口的更新方法,传入 UpdateWrapper 对象。 10. Mybatis-plus 如何进行性能优化? Mybatis-plus 的性能优化可以从以下方面入手: - 使用缓存,减少数据库访问次数。 - 合理使用分页插件,避免一次查询过多数据。 - 避免使用大量嵌套查询。 - 使用索引优化查询效率。 - 合理使用数据库连接池,避免频繁创建连接。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值