Readis常见的面试题一

1、redis的使用场景

  1. 热点数据的缓存
  2. 限时任务的操作。比如短信验证码
  3. 完成session共享的问题
  4. 完成分布式锁
  5. 商品的销售量

2、redis的持久化

     2.1什么是持久化

                把内存的数据存储到磁盘的过程,同时也可以把磁盘中的数据加载到内存中

     2.2redis实现持久化的方式 

                redis实现持久化的方式提供了两种:

                        第一种:RDB

                        第二种:AOF

                2.2.1什么是RDB

                        RDB(redis database):快照模式。每隔一段时间对内存中的数据进行块照存储。默认启动改模式

                2.2.2什么时候会触发RDB模式

                    1、手动触发

                                save  会造成线程阻塞 在执行save命令期间,redis不能处理其它命令,直到RDB过程完成

                                bgsave  不会造成线程阻塞【redis唯一使用多线程的地方】在执行bgsave命令之后会创建一个fork的线程,该线程单独执行RDB持久化 操作,而不影响其它客户对redis服务的操作

                           save和bgsave属于手动触发rdb,保存的名称为dump.rdb   

                     2、自动触发  

                                修改redis.conf配置文件

                                

                2.2.3 什么是AOF

                        AOF[append only file]:日志【每执行一个写操作】追加模式,默认redis没有开启该模式。需要手动开启。默认的文件名appendonly.aof

                         手动开启需要修改redis.conf文件

                  开启AOF只需要将appendonly yes即可

                  当启动redis服务器,会把日志文件中的命令从上到下执行一下

        2.2.4RDB和AOF的区别  

RDB快照模式,数据备份和恢复速度快。缺点:数据完整性差。缺点:数据完整性差。数据可能丢失的多。

AOF日志追加:数据完整性高。缺点:数据备份恢复速度慢

3、redis的集群环境

   redis提供了三种集群模式:

  1. 主从模式  redis3以下
  2. 哨兵模式  redis5以下
  3. 去中心化模式  

4、为什么要使用redis集群

        提高并发量和可用性 

  • 11
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java面试中,MySQL是一个常见的面试话题。以下是一些常见的MySQL面试题: 1. 如何使用explain命令来分析查询语句的执行计划以及索引的使用情况?(引用) 2. 请介绍一下MySQL的事务隔离级别以及不同数据库的具体实现情况?(引用) 3. 请列举一些常用的MySQL数据库配置文件?(引用) 4. 请介绍一下MySQL常用的引擎?(引用) 在回答这些问题时,你可以按照以下方式组织你的回答: 首先,解释explain命令的作用,它是用来分析查询语句的执行计划和索引使用情况的工具。通过使用explain命令,我们可以了解查询的执行顺序、使用的索引、扫描的行数等信息。这样可以帮助我们优化查询语句,提高查询性能。可以使用explain select * from table where type=1来演示。 然后,介绍MySQL的事务隔离级别。MySQL支持四个事务隔离级别:读未提交(Read Uncommitted)、读已提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。不同的数据库实现事务隔离级别的方式不尽相同。例如,Oracle仅实现了RC和SERIALIZABLE两个隔离级别,而MySQL则支持全部四个隔离级别。其中,默认的隔离级别是RR,但是MySQL在实现上有一些特点,如使用MVCC一致性读等。此外,MySQL的SERIALIZABLE采用了经典的实现方式,对读和写都加锁。 接下来,列举一些常用的MySQL数据库配置文件,这些配置文件包括my.cnf、my.ini和my.conf等。它们用于配置MySQL服务器的各种参数,如端口号、字符集、缓冲区大小等。通过修改这些配置文件,我们可以根据实际需求来优化MySQL的性能和功能。 最后,介绍一下MySQL常用的引擎。MySQL支持多种引擎,包括InnoDB、MyISAM、Memory、Archive等。每种引擎都具有不同的特点和适用场景。例如,InnoDB引擎支持事务和行级锁,适用于高并发和数据一致性要求较高的场景;而MyISAM引擎不支持事务,但在读写比较均衡的场景下性能较好。在选择引擎时,需要根据实际需求来进行权衡和选择。 综上所述,以上是关于Java面试中MySQL常见面试题的回答。希望对你有所帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Java 常见面试题(MySql)](https://blog.csdn.net/wang_jing_jing/article/details/116712947)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [常用mysql数据库配置文件](https://download.csdn.net/download/zslsh44/88278582)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值