Maven中Spring-Data-Redis存储对象(redisTemplate)(一)

2014-11-24 00:41:38 · 作者: · 浏览: 1

Redis是一种nosql数据库,在开发中常用做缓存。Jedis是Redis在java中的redis- client.在此之前,希望已经了解redis的基本使用和Maven的使用。建立Maven Project之后,在POM.xml中添加jedis和spring-data-redis的依赖如下:

  
	
   
    redis.clients
   
	
   
    jedis
   
	
   
    2.0.0
   
	
   
    jar
   
	
   
    compile
   

  

  

  
	
   
    org.springframework.data
   
	
   
    spring-data-redis
   
	
   
    1.0.0.RELEASE
   

  

Redis连接数据库参数如下:applicationContext-redis.properties

#redis config
redis.pool.maxActive=100
redis.pool.maxIdle=20
redis.pool.maxWait=1000
redis.pool.testOnBorrow=true
redis.hostname=localhost
redis.port=6379
redis.password=

在上下文配置中使用key-value读取方式读取properties中的值:

  

  
	
   
	
   
	
   
	
   

  

  

  
	
   
	
   
	
   
	
   

  

  	

  

上面redisTemplate已经基本配置完成。

接下来创建User类,必须实现或者间接实现Serializable接口:

Redis存储对象是使用序列化,spring-data-redis已经将序列化的功能内置,不需要我们去管,我们只需要调用api就可以使用。SerialVersionUID字段对序列化扩展有用,为了以后扩展或者缩减字段时不会造成反序列化出错。

public class User implements Serializable {

	private static final long serialVersionUID = -7898194272883238670L;

	public static final String OBJECT_KEY = "USER";

	public User() {
	}

	public User(String id) {
	}

	public User(String id, String name) {
		this.id = id;
		this.name = name;
	}

	private String id;

	private String name;

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String toString() {
		return "User [id=" + id + ", name=" + name + "]";
	}

	public String getKey() {
		return getId();
	}

	public String getObjectKey() {
		return OBJECT_KEY;
	}
}

创建userService类来操作redis增删查改缓存对象。

public class UserService {

	RedisTemplate
  
    redisTemplate;

	public RedisTemplate
   
     getRedisTemplate() { return redisTemplate; } public void setRedisTemplate(RedisTemplate
    
      redisTemplate) { this.redisTemplate = redisTemplate; } public void put(User user) { redisTemplate.opsForHash().put(user.getObjectKey(), user.getKey(), user); } public void delete(User key) { redisTemplate.opsForHash().delete(key.getObjectKey(), key.getKey()); } public User get(User key) { return (User) redisTemplate.opsForHash().get(key.getObjectKey(), key.getKey()); } }
    
   
  

在上下文中配置redisTemplate注入,在使用bean方式来注入时,redisTemplate必须有setter/getter方法:

  
	
    
     
   

  
======如果使用注解方式自动注入,则可以注释掉上面的bean配置方式======

在UserService注解@Service(“userService”),也可以在Service里写名字,默认是第一字母小写。

@Service("userService")
public class UserService {

	@Autowired
	RedisTemplate
  
    redisTemplate;
	……
        ……
}
  

在上下文配置文件中,添加自动扫描包的context节点,Base-package的路径要覆盖包含注解的类文件:
  

在main中来简单操作一下:

public class Main {
	public static void main( String[] args )
	{
		ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath*:/conf/applicationContext.xml"		);
		UserService userService =  (UserService) applicationContext.getBean("userService");
			
		User user1 = new User("user1ID", "User 1");
		User user2 = new User("user2ID", "User 2");
		
		System.out.println("==== getting objects from redis ====");
		System.out.println("User is not in redis yet: " + userService.get(user1));
		System.out.println("User is not in redis yet: " + userService.get(user2));
		
		System.out.println("==== putting objects into redis ====");
		userService.put(user1);
		userService.put(user2);
		
		System.out.pr