Spring StringRedisTemplate 配置


1 先看pom.xml

 

<dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
            <version>2.0</version>
        </dependency>
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.9.0</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-redis</artifactId>
            <version>1.6.2.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.4</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>



 

2 創建 redis.properties

 

# Redis settings
redis.host=192.168.1.88
redis.port=6379
redis.timeOut=10000
# redis.pass=

redis.maxIdle=300  
redis.maxTotal=1024  
redis.maxWaitMillis=10000  
redis.testOnBorrow=true  

 

 

3 applicationContext.xml

 

兩段配置都要

 

<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

        <property name="locations">
            <list>
                <value>classpath:redis/redis.properties</value>
            </list>
        </property>
    </bean>

 

 

<bean name="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxIdle" value="${redis.maxIdle}" />
        <property name="maxTotal" value="${redis.maxTotal}" />
        <property name="maxWaitMillis" value="${redis.maxWaitMillis}" />
        <property name="testOnBorrow" value="${redis.testOnBorrow}" />
    </bean>

    <bean name="jedisPool" class="redis.clients.jedis.JedisPool">
        <constructor-arg index="0" ref="jedisPoolConfig" />
        <constructor-arg index="1" value="${redis.host}" />
        <constructor-arg index="2" value="${redis.port}" />
        <constructor-arg index="3" value="${redis.timeOut}" />
    </bean>
    <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <property name="hostName" value="${redis.host}" />
        <property name="port" value="${redis.port}" />
        <!-- <property name="password" value="${redis.password}" />   -->
        <property name="poolConfig" ref="jedisPoolConfig" />
    </bean>
    <bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate"   p:connection-factory-ref="jedisConnectionFactory" />

 

 

4 創建Test.cs

 

 

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("/applicationContext.xml")
public class RedisTest {
    @Autowired
    StringRedisTemplate redisTemplate;

    @Test
    public void Test() throws Exception{
        redisTemplate.opsForValue().set("a","test");
        String q = redisTemplate.opsForValue().get("a")+" hello";
        System.out.println(q);
    }
}



 



比較 RedisTemplate 和 StringRedisTemplate的相關信息:

 RedisTemplate

 

方法 子API接口 描述
opsForValue() ValueOperations<K,V> 描述具有簡單值的條目
opsForList() ListOperations<K,V> 操作具有list值的條目
opsForSet() SetOperations<K,V> 操作具有set值的條目
opsForZSet() ZSetOperations<K,V> 操作具有ZSet值(排序的set)的條目
opsForHash() HashOperations<K,HK,VH> 操作具有hash值的條目
boundValueOps(K) BoundValueOperations<K,V> 以綁定指定key的方式,操作具有簡單值的條目
boundListOps(K) BoundListOperations<K,V> 以綁定指定key的方式,操作具有list的條目
boundSetOps(K) BoundSetOperations<K,V> 以綁定指定key的方式,操作具有set的條目
boundZSet(K) BoundZSetOperations<K,V> 以綁定指定key的方式,操作具有ZSet(排序的set)的條目
boundHashOps(K) BoundHashOperations<K,V> 以綁定指定key的方式,操作具有hash值的條目

 

 

StringRedisTemplate

方法 子API接口 描述
opsForValue() ValueOperations<String,String> 描述具有簡單值的條目
opsForList() ListOperations<String,String> 操作具有list值的條目
opsForSet() SetOperations<String,String> 操作具有set值的條目
opsForZSet() ZSetOperations<String,String> 操作具有ZSet值(排序的set)的條目
opsForHash() HashOperations<String,Object,Object> 操作具有hash值的條目
boundValueOps(K) BoundValueOperations<String,String> 以綁定指定key的方式,操作具有簡單值的條目
boundListOps(K) BoundListOperations<String,String> 以綁定指定key的方式,操作具有list的條目
boundSetOps(K) BoundSetOperations<String,String> 以綁定指定key的方式,操作具有set的條目
boundZSet(K) BoundZSetOperations<String,String> 以綁定指定key的方式,操作具有ZSet(排序的set)的條目
boundHashOps(K) BoundHashOperations<String,String> 以綁定指定key的方式,操作具有hash值的條目

 

 

常用方法:

轉載:http://blog.csdn.net/u011911084/article/details/53435172

 

[java]  view plain  copy
 
  1. stringRedisTemplate.opsForValue().set("test""100",60*10,TimeUnit.SECONDS);//向redis里存入數據和設置緩存時間  
[java]  view plain  copy
 
  1. stringRedisTemplate.boundValueOps("test").increment(-1);//val做-1操作  
[java]  view plain  copy
 
  1. stringRedisTemplate.opsForValue().get("test")//根據key獲取緩存中的val  
[java]  view plain  copy
 
  1. stringRedisTemplate.boundValueOps("test").increment(1);//val +1  
[java]  view plain  copy
 
  1. stringRedisTemplate.getExpire("test")//根據key獲取過期時間  
[java]  view plain  copy
 
  1. stringRedisTemplate.getExpire("test",TimeUnit.SECONDS)//根據key獲取過期時間並換算成指定單位  
[java]  view plain  copy
 
  1. stringRedisTemplate.delete("test");//根據key刪除緩存  
[java]  view plain  copy
 
  1. stringRedisTemplate.hasKey("546545");//檢查key是否存在,返回boolean值  
[java]  view plain  copy
 
  1. stringRedisTemplate.opsForSet().add("red_123""1","2","3");//向指定key中存放set集合  
[java]  view plain  copy
 
  1. stringRedisTemplate.expire("red_123",1000 , TimeUnit.MILLISECONDS);//設置過期時間  
[java]  view plain  copy
 
  1. stringRedisTemplate.opsForSet().isMember("red_123""1")//根據key查看集合中是否存在指定數據  
[java]  view plain  copy
 
  1. stringRedisTemplate.opsForSet().members("red_123");//根據key獲取set集合  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM