SpringDataRedis介绍-阿里云开发者社区

开发者社区> 游客a74jvhcp7vclg> 正文

SpringDataRedis介绍

简介: 实际项目中我们一般都会使用Redis来作为我们的缓存组件,往往又会和Spring一块使用,虽然Redis官方提供的有Jedis等客户端工具,但是使用的时候还是有些不方便,这时SpringDataRedis出现了。
+关注继续查看


 实际项目中我们一般都会使用Redis来作为我们的缓存组件,往往又会和Spring一块使用,虽然Redis官方提供的有Jedis等客户端工具,但是使用的时候还是有些不方便,这时SpringDataRedis出现了。

Redis相关单独介绍参考:https://dpb-bobokaoya-sm.blog.csdn.net/column/info/33752

SpringDataRedis

一、什么是SpringDataRedis

 SpringDataRedis是Spring大家族中的一个成员,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,支持发布订阅,并对spring 3.1 cache进行了实现。

spring-data-redis针对jedis提供了如下功能:

   连接池自动管理,提供了一个高度封装的“RedisTemplate”类

   针对jedis客户端中大量api进行了归类封装,将同一类型操作封装为operation接口

image.png

   提供的有相关的序列化器

image.png

二、怎么使用

1.创建maven项目并添加相关依赖

 创建普通的maven项目,然后添加如下依赖

<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>4.3.21.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.9.4</version>
    </dependency>
    <dependency>
        <groupId>aopalliance</groupId>
        <artifactId>aopalliance</artifactId>
        <version>1.0</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-redis</artifactId>
        <version>1.6.0.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>redis.clients</groupId>
        <artifactId>jedis</artifactId>
        <version>2.7.0</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>4.3.21.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>4.3.21.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-pool2</artifactId>
        <version>2.3</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>2.8.5</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-annotations</artifactId>
        <version>2.8.5</version>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.8.5</version>
    </dependency>
</dependencies>

2.添加相关的配置

 添加Spring的配置文件和Redis连接信息的配置文件,如下

image.png

redis.properties

redis.pool.maxTotal=20
redis.pool.maxIdle=10
redis.pool.minIdle=5

redis.conn.hostName=192.168.88.120
redis.conn.port=6379

applicationContext.xml

 注意相关的序列化器的设置,设置使用的是StringRedisSerializer

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
    <!-- 配置读取 properties 文件的工具类 -->
    <context:property-placeholder
            location="classpath:redis.properties"/>
    <!-- Jedis 连接池 -->
    <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxTotal" value="${redis.pool.maxTotal}"/>
        <property name="maxIdle" value="${redis.pool.maxIdle}"/>
        <property name="minIdle" value="${redis.pool.minIdle}"/>
    </bean>
    <!-- Jedis 的连接工厂 -->
    <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <property name="hostName" value="${redis.conn.hostName}"/>
        <property name="port" value="${redis.conn.port}"/>
        <property name="poolConfig" ref="poolConfig"/>
    </bean>
    <!-- Redis 模板对象 -->
    <bean id="redisTemplate"
          class="org.springframework.data.redis.core.RedisTemplate">
        <property name="connectionFactory"
                  ref="jedisConnectionFactory"/>
        <!-- 序列化器:能够把我们储存的 key 与 value 做序列化处理的对象 -->
        <!-- 配置默认的序列化器 -->
        <!-- keySerializer、valueSerializer 配置 Redis 中的 String 类型 key与 value 的序列化器 -->
        <!-- HashKeySerializer、HashValueSerializer 配置 Redis 中的 Hash类型 key 与 value 的序列化器 -->
        <property name="keySerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
        </property>
        <property name="valueSerializer">
            <bean  class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
        </property>
    </bean>
</beans>

3.数据存储操作

3.1 string类型操作

/**
 * @program: spring-data-redis-demo
 * @description: Redis单元测试
 * @author: 波波烤鸭
 * @create: 2019-05-19 23:45
 */
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class RedisTest {

    @Autowired
    private RedisTemplate<String,Object> redisTemplate;

    /**
     * 存储键值对
     */
    @Test
    public void test1(){
        this.redisTemplate.opsForValue().set("key","bobo kaoyao");
    }

    /**
     * 获取信息
     */
    @Test
    public void test2(){
        String msg = (String) this.redisTemplate.opsForValue().get("key");
        System.out.println("获取的值:"+msg);
    }

    /**
     * 测试连接
     */
    @Test
    public void test3(){
        Jedis jedis = new Jedis("192.168.88.120",6379);
        System.out.println(jedis.ping());
    }
}

image.png

3.2 自定义对象

/**
 * 存储自定义对象
 */
@Test
public void test4(){
    // 获取自定义对象
    Users user = new Users(1,"张三",18);
    // 更换序列化器
    this.redisTemplate.setValueSerializer(new JdkSerializationRedisSerializer());
    this.redisTemplate.opsForValue().set("users",user);
}

/**
* 获取自定义对象
*/
@Test
public void test5(){

   // 更换序列化器
   this.redisTemplate.setValueSerializer(new JdkSerializationRedisSerializer());
   Object users = this.redisTemplate.opsForValue().get("users");
   System.out.println(users);

}

image.png

3.3 存储为JSON数据

/**
 * 存储自定义对象为json数据
 */
@Test
public void test6(){
    // 获取自定义对象
    Users user = new Users(1,"张三",18);
    // 更换序列化器
    this.redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<>(Users.class));
    this.redisTemplate.opsForValue().set("usersjson",user);
}

/**
 * 获取自定义对象数据
 */
@Test
public void test7(){

    // 更换序列化器
    this.redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<>(Users.class));
    System.out.println(this.redisTemplate.opsForValue().get("usersjson"));
}

image.png

3.4 List操作

 就给出了lpush命令对应的leftpush方法,其他的参考名称操作~

/**
 * @program: spring-data-redis-demo
 * @description: Redis单元测试
 * @author: 波波烤鸭
 * @create: 2019-05-19 23:45
 */
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class RedisList {

    @Autowired
    private RedisTemplate<String, Object> redisTemplate;

    /**
     * List 类型
     */
    @Test
    public void test1() {
        this.redisTemplate.boundListOps("stus").leftPush("zhangsan");
        this.redisTemplate.boundListOps("stus").leftPush("lisi");
        this.redisTemplate.boundListOps("stus").leftPush("wangwu");
    }
}

image.png

3.5 Set操作

 /**
  * Set 类型
  */
 @Test
 public void test2() {
     redisTemplate.boundSetOps("nameset").add("bobo1");
     redisTemplate.boundSetOps("nameset").add("bobo2");
     redisTemplate.boundSetOps("nameset").add("bobo3");
 }

image.png

3.6 ZSet操作

 /**
  * ZSet 类型
  */
 @Test
 public void test3() {
     redisTemplate.boundZSetOps("namezset").add("xiaoming",90);
     redisTemplate.boundZSetOps("namezset").add("xiaohua",100);
     redisTemplate.boundZSetOps("namezset").add("xiaoli",70);
 }

image.png

3.7 Hash操作

/**
 * Hash 类型
 */
@Test
public void test4() {
    redisTemplate.boundHashOps("role").put("roleid",1001);
    redisTemplate.boundHashOps("role").put("rolename","test role");
    redisTemplate.boundHashOps("role").put("roledesc","role desc");
}

/**
 * Hash 类型 获取field对应的值
 */
@Test
public void test6() {
    Set<Object> keys = redisTemplate.boundHashOps("role").keys();
    for (Object o: keys) {
        System.out.println(o+":"+redisTemplate.boundHashOps("role").get(o));
    }
}

image.png

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
8655 0
【spring boot】11.spring-data-jpa的详细介绍和复杂使用
这篇专门用来对spring-data-jpa的详细介绍和复杂使用做一个阐述。 参考文档:https://docs.spring.io/spring-data/jpa/docs/current/reference/html/
1070 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
10478 0
Spring AOP 使用介绍,从前世到今生
原文出处:https://javadoop.com/post/spring-aop-intro 前面写过 Spring IOC 的源码分析,很多读者希望可以出一个 Spring AOP 的源码分析,不过 Spring AOP 的源码还是比较多的,写出来不免篇幅会大些。
994 0
[喵咪Redis]Redis安装与介绍
哈喽大家好啊,这次要来和大家一起来了解学习Redis的一系列技术,最终目的是搭建一个高可用redis集群自动负载灾备,那我们先从最基础的Redis的一些基本介绍以及安装来说起!
139 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
12299 0
RedisManager使用手册(六)-- 监控功能介绍
RedisManager Monitor功能和query功能介绍,Monitor模块对Redis 集群的重要指标进行监控,如平均内存占用、客户端连接数、cache命中率,节点内存碎片等,Monitor 模块中支持查看 Config、Info、Slowlog 和查询数据功能。
1878 0
+关注
游客a74jvhcp7vclg
10余年开发架构经验,同时乐于技术分享!
332
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载