Redis 的 Java 客户端有很多种, 包括 Jedis, lettuce, Redisson, java-redis-client, vertx-redis-client 及常用的 Spring 数据操作模块中的 SpringDataRedis 等等, 但是常用的就两种, Jedis 及 SpringDataRedis, 因此, 我们着重介绍一下两者的使用方式.
Jedis 也可以说是编程语言像 Java 要连接 Redis 服务器的一种途径, 当然这样的途径不止这一种, 但是 Jedis 依旧是排在 Java 客户端之首, 还是需要熟悉其操作步骤, 能够应用到实际的项目中.
步骤一: 引入依赖
从 Jedis 的官方地址中找到需要引入的依赖, 点击地址, 如下图所示:
将依赖引入到 pom.xml 中(这里我用的是 4.2.0 版本):
<dependency>
<groupId>redis.clientsgroupId>
<artifactId>jedisartifactId>
<version>4.2.0version>
dependency>
步骤二: 创建 Jedis 对象 --> 建立连接 --> 测试存入的数据 --> 释放资源
class JedisTest {
// 创建 Jedis 对象
private Jedis jedis;
@BeforeEach
void setUp() {
// 1. 建立连接
jedis = new Jedis("172.**.**.129",6379);
// 2. 设置密码
jedis.auth("123456");
// 3. 选择库
jedis.select(0);
}
// 字符串方式的存入
@Test
void testString() {
// 存入数据
String result = jedis.set("name", "qq音乐");
System.out.println("result = " + result);
// 获取数据
String name = jedis.get("name");
System.out.println("name= " + name);
}
// Hash 方式存入
@Test
void testHash() {
jedis.hset("user:1","name","Lee");
jedis.hset("user:1","age","21");
Map<String, String> map = jedis.hgetAll("user:1");
System.out.println(map);
}
@AfterEach
void tearDown() {
// 释放资源
if (jedis == null) {
jedis.close();
}
}
}
运行结果:
在这里我们可以使用Another Redis Desktop Manger 这个工具来直观的查看 Redis 中的数据, 点击Another Redis Desktop Manger下载地址 .
步骤总结:
注意: Jedis 连接池
由于 Jedis 本身是线程不安全的, 如果频繁地创建和销毁连接可能会有性能的损耗, 因此建议使用 Jedis 连接池来代替 Jedis 的连接.
创建一个 Jedis 连接池的类, 主要包含的信息有最大连接, 最大空闲连接, 最小空闲连接, 最长等待时间, 创建连接池对象, 获取连接池对象这些信息, 代码如下:
public class JedisConnectionFactory {
private static final JedisPool jedisPool;
static {
JedisPoolConfig poolConfig = new JedisPoolConfig();
// 最大连接
poolConfig.setMaxTotal(8);
// 最大空闲连接
poolConfig.setMaxIdle(8);
// 最小空闲连接
poolConfig.setMinIdle(0);
// 设置最长等待时间, ms
poolConfig.setMaxWaitMillis(200);
// 创建连接池对象 (代码中的 1000 是时间限制)
jedisPool = new JedisPool(poolConfig, "172.**.**.129",6379,1000,"123456");
}
// 获取 Jedis 对象
public static Jedis getJedis() {
return jedisPool.getResource();
}
}
连接池创建完成之后, 上面 Jedis 建立连接的过程就可以改成连接池的方式建立连接, 如下图:
SpringDataRedis 是 Redis 的集成模块, 存在于 SpringData 这个模块中, 而SpringData 又是 Spring 的数据操作模块.
SpringDataRedis 中提供了 RedisTemplate 工具类, 封装了各种对 Redis 的操作, 并将不同数据类型的操作 API 封装到了不同的类型中, 如下所示:
步骤一: 引入依赖
注意这里要引入两个依赖, 一个是 Redis 的依赖, 一个是连接池依赖; 因为这两个依赖都是 SpringBoot 提供的, 因此可以直接在 pom.xml 上直接输入这两个依赖就会自动弹出来, 如下图所示:
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-data-redisartifactId>
dependency>
<dependency>
<groupId>org.apache.commonsgroupId>
<artifactId>commons-pool2artifactId>
dependency>
步骤二: 配置文件(配置最大连接, 最大空闲连接, 最小空闲连接, 连接等待时间等)
spring:
redis:
host: 172.**.**.129
port: 6379
password: 123456
lettuce:
pool:
max-active: 10 # 最大连接
max-idle: 10 # 最小空闲连接
min-idle: 1 # 最小空闲连接
time-between-eviction-runs: 10s # 链接等待时间
步骤三: 注入 StringRedisTemplate 并进行测试
@SpringBootTest
public class RedisTest {
// 注入 StringRedisTemplate
@Resource
private StringRedisTemplate stringRedisTemplate;
@Test
void testString() {
stringRedisTemplate.opsForValue().set("name","周杰伦");
Object name = stringRedisTemplate.opsForValue().get("name");
System.out.println("name: " + name);
}
}