Jedis和SpringDataRedis

本文介绍了Jedis和SpringDataRedis的使用,包括Jedis的基本操作和优化,以及SpringDataRedis的配置和示例代码。对比两者的优缺点,指出在实际应用中如何选择。最后,列举并解答了使用过程中可能遇到的常见问题,如连接超时的解决方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Redis官方推荐使用Jedis api,但它是不完善的。
ps:由于我本人以前学习技术都是照着图片打代码,这样的学习效果不佳,所以在本文章中我会尽量使用文字阐述,但仍会尽量详尽,目的在于让各位看客多思考,遇到问题然后解决问题才有更好的学习效果。

Jedis使用

首先我们使用IDEA创建一个新的Maven project,在pom文件中添加下面的依赖:

<dependencies>
        <!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>3.0.1</version>
        </dependency>
        <!-- Junit测试依赖 -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
    </dependencies>

新建Class,简单代码如下:

public class TestJedis {
    public static void main(String[] args) {

        Jedis jedis = new Jedis("127.0.0.1",6379);	//这里应该填入自己的Redis服务器主机ip
        System.out.println("连接对象:"+jedis);
        //jedis.set("username","LangYun");
        System.out.println(jedis.get("username"));
        jedis.close();
    }
}

在此代码的基础上我们还可以进行优化,比如:

  • 把配置信息:主机ip、端口等等放入配置文件(自己实现)
  • 将jedis.close()放入finally里面,整体采用try-catch-finally结构

稍作优化后的代码(使用RedisPool):

public class TestRedisPool {
    public static void main(String[] args) {
        //1.设置连接池的配置对象
        JedisPoolConfig config = new JedisPoolConfig();
        //2.设置连接池参数
        config.setMaxTotal(30);
        //3.最大空闲
        config.setMaxIdle(10);

        //4.获取连接池对象
        JedisPool jedisPool = new JedisPool(config, "127.0.0.1", 6379);
        Jedis jedis = null;

        try {
            jedis = jedisPool.getResource();
            //5.设置数据
            /*jedis.set("nametest","LangYun");*/
            String name = jedis.get("nametest");
            System.out.println("name="+name);
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            if (jedis != null){
                jedis.close();
            }
            //虚拟机关闭的时候释放资源
            if (jedisPool != null){
                jedisPool.close();
            }
        }
    }
}

SpringDataRedis

新建maven项目,建议使用如图的项目结构
在这里插入图片描述
在pom文件中添加下面的依赖:

<!-- 集中定义依赖版本号 -->
<properties>
		<spring.version>4.2.4.RELEASE</spring.version>
</properties>

<dependencies>

        <!-- Spring -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-aspects</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jms</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.9</version>
        </dependency>

        <!-- 缓存相关 -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.8.1</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-redis</artifactId>
            <version>1.7.2.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-nop</artifactId>
            <version>1.7.2</version>
        </dependency>

    </dependencies>

新建resources/properties/redis-config.properties配置文件

redis-config.properties

#Redis settings
#server IP
redis.host=xxx.xxx.xxx.xxx
#server port
redis.port=6379
#server pass
redis.pass=
#use dbIndex
redis.database=0
#控制一个pool最多有多少个状态为idle(空闲的)的jedis实例
redis.maxIdle=300
#表示当borrow(引入)一个jedis实例时,最大的等待时间,如果超过等待时间(毫秒),则直接抛出JedisConnectionException
redis.maxWaitMillis=3000
#在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的
redis.testOnBorrow=true

新建resources/spring/applicationContext-redis.xml文件
applicationContext-redis.xml

<?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:p="http://www.springframework.org/schema/p"
        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">

    <!-- 加载properties文件 -->
    <context:property-placeholder location="classpath*:properties/*.properties"/>
    
    <!-- redis 相关配置 -->
    <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxIdle" value="${redis.maxIdle}"/>
        <property name="maxWaitMillis" value="${redis.maxWaitMillis}"/>
        <property name="testOnBorrow" value="${redis.testOnBorrow}"/>
    </bean>

    <!-- Jedis连接工厂 -->
    <bean id="JedisConnectionFactory"
          class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
          p:hostName="${redis.host}" p:port="${redis.port}" p:password="${redis.pass}" p:poolConfig-ref="poolConfig"/>

    <!-- redisTemplate类 负责操作Redis服务器封装工具类 -->
    <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
        <property name="connectionFactory" ref="JedisConnectionFactory"/>
    </bean>
</beans>

示例代码:

package com.cloud.test;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(value = "classpath:spring/applicationContext-redis.xml")
public class TestRedisTemplate {

    @Autowired
    RedisTemplate redisTemplate;

    @Test
    public void testSetString(){
        redisTemplate.boundValueOps("name").set("LangYun");
    }

    @Test
    public void testGetString(){
        System.out.println(redisTemplate.boundValueOps("name").get());
    }

    @Test
    public void deleteKey(){
        redisTemplate.delete("name");
    }
}

两者对比

 Redis的客户端有两种实现方式,一是可以直接调用Jedis来实现,二是可以使用Spring Data Redis,通过Spring的封装来调用,如何选择要根据实际情况。

Spring Data Redis优点:

  1. 对具体Redis客户端做了封装,客户端可在Jedis、Jredis、Rjc等客户端中做出选择和切换。
  2. 用template对调用做了封装,省去了建立连接,释放连接等繁琐代码。
  3. 对对象的序列化也可自由选择工具。
  4. 提供对Spring Cache的支持,可用注解实现Cache,但是无法设定缓存失效时间。

Jedis优点

  1. 可用到Jedis本身提供的更多的特性,比如Sharded,比如Masater/Slaver。

常见问题

  • 连接超时。解决方法:检查端口是否开启,如果是云服务器,就要在控制台中添加安全组其中授权对象ip设置喂0.0.0.0/0即为对所有人开发,同时还要在服务器中开放对应端口。然后重启redis服务。
  • 不要手打spring约束文件,容易出错,建议直接复制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值