Redis常见面试题(六)

news2024/11/19 9:28:27

目录

1、Redis支持的Java客户端有哪些?

2、Redisson是什么框架?

3、Redis和Redisson有什么关系?

4、Jedis和Redisson对比有什么优缺点?

5、Redis为什么不提供Windows版本?

6、Redis怎么在Windows下使用?

7、Redis如何设置密码访问?

8、Redis如何分析慢查询操作?


1、Redis支持的Java客户端有哪些?

Redisson、Jedis、 lettuce、 aredis 等等,官方推荐使用的Java客户端是: Redisson

2、Redisson是什么框架?

什么是Redisson

Redisson是Redis官方推荐的一个高级的分布式协调Redis客服端,

Redisson在基于NIO的Netty框架.上,充分的利用了Redis键值数据库提供的一系列优势;在Java实用工具包中常用接口的基础上,为使用者提供了一系列具有分布式特性的常用工具类。使得原本作为协调单机多线程并发程序的工具包获得了协调分布式多机多线程并发系统的能力,大大降低了设计和研发大规模分布式系统的难度。同时结合各富特色的分布式服务,更进一步简化了 分布式环境中程序相互之间的协作。

兼容Redis 2.6+ 与 JDK 1.6+,使用ApacheLicense 2.0授权协议.

官网: https://redisson.org/ 。

Github

GitHub - redisson/redisson: Redisson - Redis Java client with features of In-Memory Data Grid. Over 50 Redis based Java objects and services: Set, Multimap, SortedSet, Map, List, Queue, Deque, Semaphore, Lock, AtomicLong, Map Reduce, Publish / Subscribe, Bloom filter, Spring Cache, Tomcat, Scheduler, JCache API, Hibernate, MyBatis, RPC, local cache ...

适用场景

分布式应用,缓存,分布式会话,分布式任务/服务/延迟执行服务,Redis客户端等。

主要特性

云Redis管理、多样Redis配置支持、 丰富连接方式、分布式对象、分布式集合、分布式锁、分布式服务、多种序列化方式、三方框架整合、完善工具等。

●支持云托管服务模式(同时支持亚马逊云的ElastiCache Redis 和微软云的Azure Redis Cache)

1.自动发现主节点变化信小程序:

●支持Redis集群模式(同时支持亚马逊云的ElastiC ache Redis Cluster 和微软云的Azure

RedisCache) :

1.自动发现主从节点

2.自动更新状态和组态拓扑

3.自动发现槽的变化

●支持Redis哨兵模式:

1.自动发现主、从和哨兵节点

2.自动更新状态和组态拓扑

●支持Redis主从模式

●支持Redis单节模式

●多节点模式均支持读写分离:从读主写,主读主写,主从混读主写

●所有对象和接口均支持异步操作

●自行管理的弹性异步连接池

●所有操作线程安全

●支持LUA脚本

●提供分布式对象

通用对象桶(Object Bucket)、二进制流( Binary Stream )、地理空间对象桶( Geospatial. Bucket )”、BitSet、原子整长形( AtomicLong )、原子双精度浮点数(AtomicDouble)、话题 (订阅分发)、布隆过滤器( Bloom Filter) 和基数估计算法(HyperLogLog)

●提供分布式集合

映射(Map)、多值映射(Multimap) 、集( Set)、列表( List)有序集( SortedSet)、计分排序集( ScoredSortedSet )、字典排序集(LexSortedSet)、 列队(Queue) 双端队列,(Deque)年、阻塞队列( BlockingQueue)、有界阻塞列队(Bounded BlockingQueue)、阻塞双端列队( BlockingDeque )、阻塞公平列队( Blocking FairQueue)、延迟列队(Delayed Queue)、先队列 (Priority: Queue)" 和优先双端队列价(Priority Deque)

●提供分布式锁和同步器

可重入锁( Reentrant Lock)、 公平锁(FairLock )、联锁( MultiLock )、红锁(RedLock)、读写锁(ReadWriteLock)、 信号量( Semaphore )、可过期性信号量( PermitExpirableSemaphore )和闭锁微(CountDownL atch)

●提供分布式服务

分布式远程服务(Remote Service, RPC)、分布式实时对象(Live Object)服务、分布式执行服

务(Executor Service)、分 布式调度任务服务( Scheduler Service) 和分布式映射归纳服务

(MapReduce)

●支持Spring框架

提供Spring Cache集成

●提供Hibernate Cache集成

●提供JCache实现

●提供Tomcat Session Manager

●提供Spring Session集成

●:支持异步流方式执行操作

●支持Redis管道操作(批量执行)

支持安卓(Andriod)系统支持断线自动重连库

●支持命令发送失败自动重试

●支持OSGi

●支持采用多种方式自动序列化和反序列化

(Jackson  JSON,Avro,Smile,C BOR,MsgPack,Kryo,FST,LZ4 Snappy和JDK序列化)

超过1000个单元测试

与Jedis对比

Jedis是Redis的Java实现的客户端,其API提供了比较全面的Redis命令的支持; Redisson实现 了分布式和可扩展的Java数据结构和Jedis相比,功能较为简单,不支持字符串操作,不支持排序、事务、管道、分区等Redis特性。

Redisson的宗旨是促进使用者对Redis的关注分离,从而让使用者能够将精力更集中地放在处理业务逻辑上。

快速开始

Maven

Java

 

 

3、Redis和Redisson有什么关系?

Redisson是一个高级的分布式协调Redis客服端,能帮助用户在分布式环境中轻松实现一些

Java 的对象式库(Bloom filter,BitSet,Set,SetMultimap,ScoredSortedSet,SortedSet, Map,ConcurrentMap,List,ListMultimap,Queue,BlockingQueue,Deque,BlockingDeque,Semaphore,Lock,ReadWriteLock,AtomicLong,CountDownLatch, Publisha / Subscribe,HyperLogLog)。

4、Jedis和Redisson对比有什么优缺点?

Jedis是Redis的Java实现的客户端,其API提供了比较全面的Redis命令的支持。Redisson实现了分布式和可扩展的Java 数据结构,和Jedis相比,功能较为简单,不支持字符串操作,不支持排序、事务、管道、分区等Redis 特性。

Redisson的宗旨是促进使用者对Redis的关注分离,从而让使用者能够将精力更集中地放在处理业务逻辑上。

5、Redis为什么不提供Windows版本?

因为目前Linux版本已经相当稳定,而且用户量很大,无需开发Windows版本,反而会带来兼容性等问题,所以官网没有Windows版本可以下载。

6、Redis怎么在Windows下使用?

官方没有提供Windows版本,不过,微软提供了开源的windows版本:

https://github.com/MicrosoftArchive/redis/releases

Windows版本基于Redis 3.0.504,好几年没有更新了,

所以我也不建议大家在windows,下使用Redis。

7、Redis如何设置密码访问?

命令设置密码

这种方式是临时的,重启后需要重新设置。

config set requirepass 123456

配置设置密码

redis. conf中添加配置:

requirepass 123456

授权密码:

有两种方式:

auth 123456

$ ./redis-cli -P 9001 -a 123456

8、Redis如何分析慢查询操作?

什么是慢查询

和mysq|的慢SQL日志分析一样,redis也有类似的功能,来帮助定位一-些慢查询操作。

Redis slowlog是Redis用来记录查询执行时间的日志系统。

查询执行时间指的是不包括像客户端响应(talking)、发送回复等IO操作,而单单是执行一个查询命令所耗费的时间。

另外,slowlog保存在内存里面,读写速度非常快,因此你可以放心地使用它,不必担心因为开启slowlog而损害Redis的速度。

慢查询参数

首先来关注下慢日志分析对应的两个参数:

1、 slowlog-log-slower-than: 预设阀值,即

记录超过多少时间的记录,默认为10000微秒 ,即10毫秒。

  1. slowlog-max-len: 记录慢查询的条数,默认为128条,当超过设置的条数时最早进入队列的将被移除。线上建议增大数值,如: 1000,这样可减少队列移除的频率。

可以用config: set对这两个参数进行调整,或者在

配置文件中设置。

 

慢查询命令

语法: slowlog subcommand [argument]

如,进行查询慢查询、获取慢查询记录的数量、重置慢查询日志等操作:

 

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

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

相关文章

前端线上问题如何调试

记录Vue开发过程中遇到的问题,测试环境以及本地显示都没有问题,但是一上线就出现问题,于是对于这个问题进行排查,在此记录排查问题的步骤以及方法,希望对大家有帮助。 错误信息:Uncaught TypeError: Canno…

Redis常见面试题(七)

目录 1、什么是缓存预热? 2、什么是缓存热备? 3、什么是缓存雪崩? 4、如何解决缓存雪崩? 5、什么是缓存穿透? 6、如何解决缓存穿透? 7、什么是缓存击穿? 8、如何解决缓存击穿? 9、什么是缓存抖动? 10、如何解决缓存抖动? 11、什么是缓存无底洞? 12、如何…

如何让一个 C 语言项目调用另一个 C++ 项目中某些类所提供的接口?

目前問題是這樣的:有兩個項目 一個項目是用 C 寫的 裏面提供了一個輸入輸出接口 後來從外面弄來了另外一個項目 用 C 寫的 現在需要將 C 項目中所使用的原有接口替換為使用我們的 C 項目中提供的接口 求問能夠實現否? 在项目开发过程中,我们底…

XGBoost总结

1.算法原理 XGBoost是boosting算法的其中一种。Boosting算法的思想是将许多弱分类器集成在一起形成一个强分类器。因为XGBoost是一种提升树模型,该算法思想就是不断地添加树,不断地进行特征分裂来生长一棵树,每次添加一个树,其实…

CSS3之3D转换

文章目录一、3D移动translate3d二、perspective(透视)三、translateZ四、rotateX-rotateY-rotateZ五、rotate3d(x,y,z,deg)六、3D呈现transfrom-style七、旋转木马案例一、3D移动translate3d 3D移动在2D移动的基础上多加了一个可以移动的方向&#xff0…

Python 函数用法和底层分析

【无限嚣张(菜菜)】:hello您好,我是菜菜,很高兴您能来访我的博客,我是一名爱好编程学习研究的菜菜,每天分享自己的学习,想法,博客来源与自己的学习项目以及编程中遇到问题…

Android编译ZLMediaKit之实现NVR功能问题点记录

NVR功能 NVR,全称Network Video Recorder,即网络视频录像机,是网络视频监控系统的存储转发部分,NVR与视频编码器或网络摄像机协同工作,完成视频的录像、存储及转发功能。 一、git clone项目 git clone --recursive …

ES 的存储原理

目录 一、ES是什么 二、ES基本结构 2.1、结构图 2.2、基本概念 2.3、与关系数据库概念的类比 2.4、数据如何读写 2.5 容灾能力 三、ES的文件存储结构 每个分片的事务日志(Transaction Log) Index文件夹内文件含义(lucene文件夹) 四、存储步骤…

计算机必备小知识【数据库字段、估算内存】

计算机必备小知识【数据库、内存】 1 mysql数存储类型(database) 1.1 char与varcha区别 char的存储空间是固定长度;varchar是可变长varchar会比char多1至2个字节来存放数据的长度 1.2 varchar存储 ①varchar能存多少汉字、数字呢&#x…

直播弹幕系统(六)- SpringBoot + STOMP + RabbitMQ(使用MQ替代Spring代理)

直播弹幕系统(六)- SpringBoot STOMP RabbitMQ(使用MQ替代Spring代理)前言一. SpringBoot整合RabbitMQ代理Broker1.1 RabbitMQ安装STOMP插件(Docker)1.2 RabbitMQ相关准备1.3 其他代码二. 前端整合Rabbit…

Prometheus_原理架构-安装部署

文章目录1、prometheus简介常见监控软件优势2、组成图讲解3、安装和配置3.1 容器安装3.2 二进制安装3.3 配置热加载1、prometheus简介 是一个监控软件–》监控容器非常好,也可以监控其他的非容器的机器的业务,例如:MySQL,nginx&am…

locksupport的park和unpark

locksupport是什么 LockSupport是一个线程阻塞工具类,所有的方法都是静态方法,可以让线程在任意位置阻塞,当然阻塞之后肯定得有唤醒的方法。 有什么用 接下面我来看看LockSupport有哪些常用的方法。主要有两类方法:park和unpar…

java:jackson 二:Custom Deserialization in Jackson

java:jackson 二:Custom Deserialization in Jackson 1 前言 jackson支持自定义反序列化器,参考文档地址如下: https://www.baeldung.com/jacksonhttps://www.baeldung.com/jackson-deserialization依赖如下(这里使…

基于FPGA的幅频均衡带通滤波器的设计

目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 数字通信系统中,由于多径传输、信道衰落等影响,在接收端会产生严重的码间干扰,增大误码率。为了克服码间干扰,提高通信系统的性能,在接…

记录Android Jni编译过程

Gradle配置 我们主要看这个配置文件里面吧,这里面有关于ndk配置的选项。 大概介绍一下,这里面一些字段是干嘛的。 我们看,这里面有两个相仿的字段,都是externalNativeBuild字段,但是位于两个不同的位置,其…

小程序02/小程序 响应式单位rpx 、image组件概念说明 和 mode属性介绍

一. 响应式单位rpx rpx 说明 rpx: 规定不管屏幕为多少px , 100%的屏幕宽度就是750rpx 100% 屏幕的宽度 750rpx rpx响应单位 rpx是微信小程序独有的,解决屏幕自适应的尺寸单位 可以根据屏幕宽度进行自适应,不论大小屏幕,规定屏幕宽为750…

数据首发!空气悬挂前装搭载率破1%,明年冲刺70万套

新能源智能化的合力变革,带动汽车行业进入新的发展周期:如何进一步提升整车轻量化、驾驶和乘坐的安全和体验。这其中,乘用车悬挂系统也在发生新的变化。 此前,除了传统固定式金属螺旋弹簧悬挂,主动悬架系统的前装上车主…

学计算机网络太难?原来方法没用对...

计算机世界里的三座大山: 计算机网络,操作系统,算法与数据结构。跨过去的人都是神一样的存在了。 学计算机网络也要讲究学习方法 从实际案例出发(比如我们在浏览器输入一个网址到展示出内容中间发生了什么事情) 计算机网络出现的…

简单记录一下怎么看package.json文件

首先每个vue工程文件从仓库克隆代码下来的时候,一般都会包含这个文件,这个文件非常重要,package.json包含了关于项目重要信息,如下图所示 其中包含了name、version、description、author、scripts、dependencies、devDependencies…

Django基础

Django 1.项目的创建 创建项目: 删除一些内容: settings.py中: 2.默认项目文件的介绍 3.APP 创建APP: APP文件介绍: 4.快速上手 APP注册: 在app中找到apps.py: 在django的项目setti…