目录
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毫秒。
- slowlog-max-len: 记录慢查询的条数,默认为128条,当超过设置的条数时最早进入队列的将被移除。线上建议增大数值,如: 1000,这样可减少队列移除的频率。
可以用config: set对这两个参数进行调整,或者在
配置文件中设置。
慢查询命令
语法: slowlog subcommand [argument]
如,进行查询慢查询、获取慢查询记录的数量、重置慢查询日志等操作: