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连接来完成各种操作。