jedis是Redis推荐的Java连接Redis客户端,但是实际上springboot2推荐的是连接Redis客户端是lettuce (实际上对应比较流行的客户端还有一个redisson),主要是jedis好久不更新对新的功能支持没有另外的好(本身Springboot2的选择也是一个侧面说明,关键是lettuce是线程安全的,jedis不是。)
一 先来个jedis的简单demo
pom文件配置
<!--导入jredis的包-->
<dependencies>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>3.2.0</version>
</dependency>
<!--fastjson-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.70</version>
</dependency>
</dependencies>
测试代码
/**
* @Author: zhangpeng
* @Date: 2022/2/8 16:03
*/
public class TestPing {
public static void main(String[] args) {
Jedis jedis = new Jedis("192.168.XX.XX", 17006);
jedis.auth("XXXXXX");
String response = jedis.ping();
System.out.println(response); // PONG
}
}
二 springboot整合Redis
初始化项目,除了我们常勾选的web,还要注意勾选NoSQL的Redis
我们不是说lettuce代替jedis了吗,怎么看?可以去pom文件找springboot 的redis配置,如图,点击过去
会展示如下:
再说一下两者区别差异:
jedis:采用的直连,多个线程操作的话,是不安全的。如果要避免不安全,使用jedis pool连接池!更像BIO模式(同步阻塞的)
lettuce:采用netty,实例可以在多个线程中共享,不存在线程不安全的情况!可以减少线程数据了,更像NIO模式(同步非阻塞的)
一 RedisAutoConfiguratio
RedisAutoConfiguratio是springdata的redis自动配置类。
// IntelliJ API Decompiler stub source generated from a class file
// Implementation of methods is not available
package org.springframework.boot.autoconfigure.data.redis;
@org.springframework.context.annotation.Configuration(proxyBeanMethods = false)
@org.springframework.boot.autoconfigure.condition.ConditionalOnClass({org.springframework.data.redis.core.RedisOperations.class})
@org.springframework.boot.context.properties.EnableConfigurationProperties({org.springframework.boot.autoconfigure.data.redis.RedisProperties.class})
@org.springframework.context.annotation.Import({org.springframework.boot.autoconfigure.data.redis.LettuceConnectionConfiguration.class, org.springframework.boot.autoconfigure.data.redis.JedisConnectionConfiguration.class})
public class RedisAutoConfiguration {
public RedisAutoConfiguration() { /* compiled code */ }
@org.springframework.context.annotation.Bean
@org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean(name = {"redisTemplate"})
@org.springframework.boot.autoconfigure.condition.ConditionalOnSingleCandidate(org.springframework.data.redis.connection.RedisConnectionFactory.class)
public org.springframework.data.redis.core.RedisTemplate<java.lang.Object,java.lang.Object> redisTemplate(org.springframework.data.redis.connection.RedisConnectionFactory redisConnectionFactory) { /* compiled code */ }
@org.springframework.context.annotation.Bean
@org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean
@org.springframework.boot.autoconfigure.condition.ConditionalOnSingleCandidate(org.springframework.data.redis.connection.RedisConnectionFactory.class)
public org.springframework.data.redis.core.StringRedisTemplate stringRedisTemplate(org.springframework.data.redis.connection.RedisConnectionFactory redisConnectionFactory) { /* compiled code */ }
}
只有两个Bean:
- RedisTemplate 默认的template,你也可以重写一个这个
- StringRedisTemplate 针对String使用的频率比较高的tempalte
在RedisTemplate上也有一个条件注解,说明我们是可以对其进行定制化的
开始测试
(一)配置文件
# 配置redis
spring.redis.host=192.168.XX.XX
spring.redis.port=XXXX
# Redis服务器连接密码(默认为空)
spring.redis.password=XXXX
(二)测试demo
@SpringBootTest
class ZpRedis2ApplicationTests {
@Resource
private RedisTemplate redisTemplate;
@Test
void contextLoads() {
// redisTemplate 操作不同的数据类型,api和我们的指令是一样的
// opsForValue 操作字符串 类似String
// opsForList 操作List 类似List
// opsForHah
// 除了基本的操作,我们常用的方法都可以直接通过redisTemplate操作,比如事务和基本的CRUD
// 获取连接对象
//RedisConnection connection = redisTemplate.getConnectionFactory().getConnection();
//connection.flushDb();
//connection.flushAll();
redisTemplate.opsForValue().set("mykey111","zhangpeng");
System.out.println(redisTemplate.opsForValue().get("mykey111"));
System.out.println(redisTemplate.opsForValue().get("mykey111"));
}
}