优秀的编程知识分享平台

网站首页 > 技术文章 正文

CentOS,安装Redis5,Java客户端Jedis、Lettuce和Redisson对比

nanyue 2024-09-01 00:06:58 技术文章 4 ℃

CentOS安装redis5

Redis

Redis(Remote Dictionary Server),远程字典服务,是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

下载地址:

https://download.redis.io/releases/redis-5.0.14.tar.gz

安装到目录/opt/module下

sudo yum install -y gcc g++ gcc-c++
sudo yum install tcl
mkdir /opt/software
mkdir /opt/module
wget https://download.redis.io/releases/redis-5.0.14.tar.gz
tar -zxvf redis-5.0.14.tar.gz -C /opt/module/
cd /opt/module/
mv redis-5.0.14 redis5
cd redis5/
make MALLOC=libc
make install PREFIX=/opt/module/redis5

注:安装完成后,redis5目录下多了bin目录。

环境变量配置操作

# 添加环境变量(sudo vim /etc/profile.d/my_en.sh):
#REDIS_HOME
export REDIS_HOME=/opt/module/redis5
export PATH=$PATH:$REDIS_HOME/bin
# 使环境变量生效
. /etc/profile
echo $REDIS_HOME

配置文件redis.conf

#守护进程
daemonize yes
#关闭保护模式
protected-mode no
#绑定服务地址
bind 192.168.2.56
#配置认证密码
requirepass 123456

启停redis

redis-server /opt/module/redis5/redis.conf
ps -ef | grep redis
netstat -ano | grep 6379
客户端连接:
redis-cli -h ip地址 -c -p 6379

Java客户端

Jedis、Lettuce和Redisson

Jedis,https://github.com/redis/jedis

<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>4.3.0</version>
</dependency>

redission,https://github.com/redisson/redisson/wiki/%E7%9B%AE%E5%BD%95

<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson</artifactId>
    <version>3.17.6</version>
</dependency>

Lettuce,https://lettuce.io/,https://github.com/lettuce-io/lettuce-core

<dependency>
    <groupId>io.lettuce</groupId>
    <artifactId>lettuce-core</artifactId>
    <version>6.1.6.RELEASE</version>
</dependency>

Jedis和Redisson

都是Java中对Redis操作的封装,Jedis只是简单的封装了Redis的API库,可以看作是Redis客户端,它的方法和Redis的命令很类似,Redisson不仅封装了redis,还封装了对更多数据结构的支持,以及锁等功能,相比于Jedis更加大,Jedis相比于Redisson更原生一些,更灵活。

Jedis和Lettuce

都是Redis的客户端,在SpringBoot2.0之后默认都是使用的Lettuce这个客户端连接Redis,当使用Jedis客户端连接Redis服务器的时,每个线程都要拿自己创建的Jedis实例去连接Redis客户端,有很多个线程时,不仅开销大需要反复的创建关闭一个Jedis连接,而且也是线程不安全的,一个线程通过Jedis实例更改Redis服务器中的数据之后会影响另一个线程。

相互对比

Jedis:是Redis的Java实现客户端,提供了比较全面的Redis命令的支持;

Redisson:实现了分布式和可扩展的Java数据结构;

Lettuce:高级Redis客户端,用于线程安全同步,异步和响应使用,支持集群,Sentinel,管道和编码器。

各自优点:

Jedis:比较全面的提供了Redis的操作特性;

Redisson:促使使用者对Redis的关注分离,提供很多分布式相关操作服务,例如,分布式锁,分布式集合,可通过Redis支持延迟队列;

Lettuce:主要在一些分布式缓存框架上使用比较多。

可伸缩性:

Jedis:使用阻塞的I/O,且其方法调用都是同步的,程序流需要等到sockets处理完I/O才能执行,不支持异步,Jedis客户端实例线程不安全,需要通过连接池来使用Jedis;

Redisson:基于Netty框架的事件驱动的通信层,其方法调用是异步的,redisson的API是线程安全的,可以操作单个Redisson连接来完成各种操作;

Lettuce:基于Netty框架的事件驱动的通信层,其方法调用是异步的,Lettuce的API是线程安全的,所以可以操作单个Lettuce连接来完成各种操作。

Tags:

最近发表
标签列表