Java关于RedisTemplate的使用分析

这篇文章主要讲解如何使用RedisTemplate以及解释部分源码

对于方法的源码或者方法使用此处没有讲解,之前写过太多类似的

(实战再去查看相关函数,会更加明白深层次的含义)

对于Redis的知识原理以及各个方法的使用之前也有写过很多类似的,可看我之前的文章进行参考:

  • Redis框架从入门到学精(全)
  • Python操作Redis从入门到精通附代码(全)
  • 一文读懂基于Redis的Amazon MemoryDB数据库

1. 源码

查看对应的 RedisAutoConfiguration 源码信息

// 配置类
@AutoConfiguration

// 只匹配指定的类在类路径上
@ConditionalOnClass(RedisOperations.class)

// 开启配置累的注解
@EnableConfigurationProperties(RedisProperties.class)
@Import({
  LettuceConnectionConfiguration.class, JedisConnectionConfiguration.class })
public class RedisAutoConfiguration {
 
	
	// 这个注解比较重要,通过Bean装配到spring容器中
	@Bean
	// 只有在BeanFactory中没有包含满足指定需求的bean时才匹配
	@ConditionalOnMissingBean(name = "redisTemplate")
	// 只有当指定类的bean已经包含在BeanFactory中并且可以确定单个候选bean时才匹配,本质上,主要定义的类型自动连接bean就会成功匹配
	@ConditionalOnSingleCandidate(RedisConnectionFactory.class)
	// 看此处两个都是Object,说明key 以及value 都是什么类型都可以
	public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
 
		RedisTemplate template = new RedisTemplate<>();
		template.setConnectionFactory(redisConnectionFactory);
		return template;
	}

	@Bean
	@ConditionalOnMissingBean
	@ConditionalOnSingleCandidate(RedisConnectionFactory.class)
	// 而此处的key value均为string类型,可看下面的代码
	public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
 
		return new StringRedisTemplate(redisConnectionFactory);
	}

}

StringRedisTemplate类型的key以及value为String

源码如下:

public class StringRedisTemplate extends RedisTemplate {
 
	public StringRedisTemplate() {
 
		// 设置key以及value,hash的key以及value都是string类型
		setKeySerializer(RedisSerializer.string());
		setValueSerializer(RedisSerializer.string());
		setHashKeySerializer(RedisSerializer.string());
		setHashValueSerializer(RedisSerializer.string());
	}
	.....
}

对应的RedisTemplate的相关方法,大部分都是 org.springframework.data.redis.core.RedisOperations 这个类的相关方法,主要是RedisOperations这个类提供的API,比如设置key,value以及查出value值等(对应几种数据结构)

以下分别五种数据结构如下:

函数

描述

redisTemplate.opsForCluster()

操作集群

redisTemplate.opsForGeo()

操作地理位置(对于Geo的实际应用,这篇文章末尾有: Redis框架从入门到学精(全) )

redisTemplate.opsForHash()

操作Hash

redisTemplate.opsForList()

操作List

redisTemplate.opsForValue()

操作字符串

redisTemplate.opsForSet()

操作set

redisTemplate.opsForZSet()

操作有序set

其中StringRedisTemplate操作的方法只不过把对应的类型换作为String类型

关于RedisTemplate以及StringRedisTemplate,两者是不相通的,两者各自调用各自的数据

类似每一种类型都有很多种方法,大致如下:

根据不同的方法设置不同的参数以及查询获取等

2. 示例代码

引入redis的maven包

具体通过: maven 关于redis data的仓库



    org.springframework.boot
    spring-boot-starter-data-redis
    2.7.3

redis的相关连接信息

通过yml的配置文件引入:(redis有设置密码的时候还需要设置密码)

spring: 
  redis:
    host: IP
    password: pwd
    port: 6379

如果为application.properties的配置文件,配置文件这样引入:

spring.redis.host=IP
# Redis服务器连接端口
spring.redis.port=6379

通过上面这两个步骤已经就可使用RedisTeplate(通过@Autowired注入)

(上面的源码已经对RedisTeplate类通过@Bean装载到spring容器中)

示例代码如下:

package com.example.demo;

import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.core.ValueOperations;

@SpringBootTest
class DemoApplicationTests {
 

    @Autowired
    StringRedisTemplate stringRedisTemplate;
    @Test
    public void test() {
 
        ValueOperations ops = stringRedisTemplate.opsForValue();
        ops.set("name","码农研究僧");
        String s = ops.get("name");
        System.out.println(s);
    }

}

截图如下:

发表评论
留言与评论(共有 0 条评论) “”
   
验证码:

相关文章

推荐文章