1、pom.xml依赖
 <!--Redis相关依赖-->
 <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-data-redis</artifactId>
 </dependency>

 2、配置文件
 # Redis服务器连接端口
 spring.redis.port=6379
 # Redis服务器地址
 spring.redis.host=127.0.0.1# 或者
 # Redis集群
 # spring.redis.cluster.nodes=127.0.0.1:6379,127.0.0.1:6380,127.0.0.1:6381
 # Redis最大重定向(默认为5)
 # spring.redis.cluster.max-redirects=5# Redis数据库索引(默认为0)
 spring.redis.database=0
 # Redis服务器连接密码(默认为空)
 spring.redis.password=
 # 连接池最大连接数(使用负值表示没有限制)
 spring.redis.jedis.pool.max-active=8
 # 连接池最大阻塞等待时间(使用负值表示没有限制)
 spring.redis.jedis.pool.max-wait=-1ms
 # 连接池中的最大空闲连接
 spring.redis.jedis.pool.max-idle=8
 # 连接池中的最小空闲连接
 spring.redis.jedis.pool.min-idle=0
 # 连接超时时间(毫秒)
 spring.redis.timeout=5000ms

 3、RedisTemplate的基本方法
 首先使用@Autowired注入RedisTemplate(后面直接使用,就不特殊说明)//导入redisTemplate
 @Autowired
 private RedisTemplate redisTemplate;

 1.删除单个key//    删除单个key
 public void delete(String key){
     redisTemplate.delete(key);
 }

 2.删除多个key//    删除多个key
 public void deleteKeys (String ...keys){
     redisTemplate.delete(keys);
 }

 3.指定key的过期时间//    指定key的失效时间
 public void setExpire(String key,long time){
     redisTemplate.expire(key, time, TimeUnit.MINUTES);
 }

 4.获取key的过期时间//    根据key获取过期时间
 public long getExpire(String key){
     Long expire = redisTemplate.getExpire(key);
     return expire;
 }

 5.判断key是否存在//    判断key是否存在
 public boolean hasKey(String key){
     return redisTemplate.hasKey(key);
 }

 4、String类型相关操作
 1.添加缓存//1、通过BoundValueOperations设置值
 redisTemplate.boundValueOps("StringKey").set("StringValue");
 redisTemplate.boundValueOps("StringKey").set("StringValue",1, TimeUnit.MINUTES);//2、通过ValueOperations设置值
 redisTemplate.opsForValue().set("StringKey", "StringVaule");
 redisTemplate.opsForValue().set("StringValue","StringVaule",1, TimeUnit.MINUTES);

 2.设置过期时间(单独设置)redisTemplate.boundValueOps("StringKey").expire(1,TimeUnit.MINUTES);
redisTemplate.expire("StringKey",1,TimeUnit.MINUTES);

 3.获取缓存值//1、通过BoundValueOperations获取值
 String StringVaule= redisTemplate.boundValueOps("StringKey").get();//2、通过ValueOperations获取值
 String StringVaule= redisTemplate.opsForValue().get("StringKey");

 4.顺序递增//每次自增3
 redisTemplate.boundValueOps("StringKey").increment(3L);
 //每次自增5
 redisTemplate.opsForValue().increment("StringKey",5);
 //每次自增1
 redisTemplate.opsForValue().increment("StringKey");

 5.顺序递减redisTemplate.boundValueOps("StringKey").increment(-3L);
 redisTemplate.opsForValue().increment("StringKey",-5);

 5、Hash类型相关操作
 1.添加缓存//1、通过BoundValueOperations设置值
 BoundHashOperations hashKey = redisTemplate.boundHashOps("HashKey");
 hashKey.put("SmallKey", "HashVaue");//2、通过ValueOperations设置值
 HashOperations hashOps = redisTemplate.opsForHash();
 hashOps.put("HashKey", "SmallKey", "HashVaue");

 2.设置过期时间(单独设置)redisTemplate.boundValueOps("HashKey").expire(1,TimeUnit.MINUTES);
redisTemplate.expire("HashKey",1,TimeUnit.MINUTES);

 3.添加一个Map集合HashMap<String, String> hashMap = new HashMap<>();
 redisTemplate.boundHashOps("HashKey").putAll(hashMap );

 4.获取所有key//1、通过BoundValueOperations获取值
 BoundHashOperations hashKey = redisTemplate.boundHashOps("HashKey");
 Set keys1 = hashKey.keys();//2、通过ValueOperations获取值
 HashOperations hashOps = redisTemplate.opsForHash();
 Set keys2 = hashOps.keys("HashKey");

 5.获取所有value//1、通过BoundValueOperations获取值
 BoundHashOperations hashKey = redisTemplate.boundHashOps("HashKey");
 List values1 = hashKey.values();//2、通过ValueOperations获取值
 HashOperations hashOps = redisTemplate.opsForHash();
 List values2 = hashOps.values("HashKey");

 6.根据key获取value值//1、通过BoundValueOperations获取值
 BoundHashOperations hashKey = redisTemplate.boundHashOps("HashKey");
 String value1 = hashKey.get("SmallKey");//2、通过ValueOperations获取值
 HashOperations hashOps = redisTemplate.opsForHash();
 String value2 = hashOps.get("HashKey", "SmallKey");

 7.获取所有的键值对集合//1、通过BoundValueOperations获取值
 BoundHashOperations hashKey = redisTemplate.boundHashOps("HashKey");
 Map entries1 = hashKey.entries();//2、通过ValueOperations获取值
 HashOperations hashOps = redisTemplate.opsForHash();
 Map entries2 = hashOps.entries("HashKey");

 8.删除//删除小key
 redisTemplate.boundHashOps("HashKey").delete("SmallKey");
 //删除大key
 redisTemplate.delete("HashKey");

 9.判断Hash中是否含有该值Boolean isEmpty = redisTemplate.boundHashOps("HashKey").hasKey("SmallKey");
Boolean isEmpty = redisTemplate.opsForHash().hasKey("HashKey","SmallKey");

 6、Set类型相关操作
 1.添加Set缓存(值可以是一个,也可是多个)(2/3是1的递进值)//1、通过BoundValueOperations设置值
 BoundSetOperations setKey = redisTemplate.boundSetOps("setKey");
 setKey.add("setValue1", "setValue2", "setValue3");//2、通过ValueOperations设置值
 SetOperations setOps = redisTemplate.opsForSet();
 setOps.add("setKey", "SetValue1", "setValue2", "setValue3");

 2.设置过期时间(单独设置)redisTemplate.boundValueOps("setKey").expire(1,TimeUnit.MINUTES);
redisTemplate.expire("setKey",1,TimeUnit.MINUTES);

 3.根据key获取Set中的所有值//1、通过BoundValueOperations获取值
 BoundSetOperations setKey = redisTemplate.boundSetOps("setKey");
 Set set1 = setKey.members();//2、通过ValueOperations获取值
 SetOperations setOps = redisTemplate.opsForSet();
 Set set2 = setOps.members("setKey");

 4.根据value从一个set中查询,是否存在Boolean isEmpty = redisTemplate.boundSetOps("setKey").isMember("setValue2");

 5.获取Set缓存的长度Long size = redisTemplate.boundSetOps("setKey").size();

 6.移除指定的元素Long result1 = redisTemplate.boundSetOps("setKey").remove("setValue1");

 7.移除指定的keyBoolean result2 = redisTemplate.delete("setKey");

 7、 LIST类型相关操作
 1.添加缓存//1、通过BoundValueOperations设置值
 BoundListOperations listKey = redisTemplate.boundListOps("listKey");
 listKey.leftPush("listLeftValue3");
 listKey.rightPush("listRightValue4");//2、通过ValueOperations设置值
 ListOperations opsList = redisTemplate.opsForList();
 opsList.leftPush("listKey", "listLeftValue5");
 opsList.rightPush("listKey", "listRightValue6");

 2.将List放入缓存ArrayList<String> list = new ArrayList<>();
 redisTemplate.boundListOps("listKey").rightPushAll(list);
 redisTemplate.boundListOps("listKey").leftPushAll(list);

 3.设置过期时间(单独设置)redisTemplate.boundValueOps("listKey").expire(1,TimeUnit.MINUTES);
redisTemplate.expire("listKey",1,TimeUnit.MINUTES);

 4.获取List缓存全部内容(起始索引,结束索引)List listKey1 = redisTemplate.boundListOps("listKey").range(0, 10); 

 5.从左或从右弹出一个元素String listKey2 = (String) redisTemplate.boundListOps("listKey").leftPop();  //从左侧弹出一个元素
 String listKey3 = (String) redisTemplate.boundListOps("listKey").rightPop(); //从右侧弹出一个元素

 6.根据索引查询元素String listKey4 = (String) redisTemplate.boundListOps("listKey").index(1);

 7.获取List缓存的长度Long size = redisTemplate.boundListOps("listKey").size();

 8.根据索引修改List中的某条数据(key,索引,值)redisTemplate.boundListOps("listKey").set(3L,"listLeftValue3");

 9.移除N个值为value(key,移除个数,值)redisTemplate.boundListOps("listKey").remove(3L,"value");

 8、Zset类型的相关操作
 1.向集合中插入元素,并设置分数//1、通过BoundValueOperations设置值
 BoundZSetOperations zSetKey = redisTemplate.boundZSetOps("zSetKey");
 zSetKey.add("zSetVaule", 100D);//2、通过ValueOperations设置值
 ZSetOperations zSetOps = redisTemplate.opsForZSet();
 zSetOps.add("zSetKey", "zSetVaule", 100D);

 2.向集合中插入多个元素,并设置分数DefaultTypedTuple<String> p1 = new DefaultTypedTuple<>("zSetVaule1", 2.1D);
 DefaultTypedTuple<String> p2 = new DefaultTypedTuple<>("zSetVaule2", 3.3D);
 redisTemplate.boundZSetOps("zSetKey").add(new HashSet<>(Arrays.asList(p1,p2)));

 3.按照排名先后(从小到大)打印指定区间内的元素, -1为打印全部Set<String> range = redisTemplate.boundZSetOps("zSetKey").range(key, 0, -1);

 4.获得指定元素的分数Double score = redisTemplate.boundZSetOps("zSetKey").score("zSetVaule");

 5.返回集合内的成员个数Long size = redisTemplate.boundZSetOps("zSetKey").size();

 6.返回集合内指定分数范围的成员个数(Double类型)Long COUNT = redisTemplate.boundZSetOps("zSetKey").count(0D, 2.2D);

 7.返回集合内元素在指定分数范围内的排名(从小到大)Set byScore = redisTemplate.boundZSetOps("zSetKey").rangeByScore(0D, 2.2D);

 8.带偏移量和个数,(key,起始分数,最大分数,偏移量,个数)Set<String> ranking2 = redisTemplate.opsForZSet().rangeByScore("zSetKey", 0D, 2.2D 1, 3);
 9.返回集合内元素的排名,以及分数(从小到大)
Set<TypedTuple<String>> tuples = redisTemplate.boundZSetOps("zSetKey").rangeWithScores(0L, 3L);
   for (TypedTuple<String> tuple : tuples) {
       System.out.println(tuple.getValue() + " : " + tuple.getScore());
   }

 10.返回指定成员的排名//从小到大
 Long startRank = redisTemplate.boundZSetOps("zSetKey").rank("zSetVaule");
 //从大到小
 Long endRank = redisTemplate.boundZSetOps("zSetKey").reverseRank("zSetVaule");

 11.从集合中删除指定元素redisTemplate.boundZSetOps("zSetKey").remove("zSetVaule");
 12.删除指定索引范围的元素(Long类型)redisTemplate.boundZSetOps("zSetKey").removeRange(0L,3L);
 13.删除指定分数范围内的元素(Double类型)redisTemplate.boundZSetOps("zSetKey").removeRangeByScorssse(0D,2.2D);
 14.为指定元素加分(Double类型)Double score = redisTemplate.boundZSetOps("zSetKey").incrementScore("zSetVaule",1.1D);