jedis与spring整合及简单的使用RedisTemplate操作

整理一下redis与spring的整合。以及使用redisTemplate。首先是要导入spring所需要的jar。当然还有 jedis-2.1.0.jar,commons-pool-1.5.4.jar,spring-data-redis-1.0.0.RELEASE.jar  (这是我使用的版本,应该不新)

1. 导入完这些jar,开始整理配置文件:

首先就是web.xml。这个还是老样子:贴一下吧


        contextConfigLocation
        classpath:applicationContext*.xml
    
    
        class>org.springframework.web.context.ContextLoaderListenerclass>
    

还有就是spring配置文件,大家也就一看就明白了。我还是叫做applicationContext.xml,



    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
    http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.5.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context-2.5.xsd
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd" default-lazy-init="false">
    
    
    
    package="com.demo" />
    


    class="redis.clients.jedis.JedisPoolConfig">
        
        
        
        
    

    class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        
        
        
    

    class="org.springframework.data.redis.core.RedisTemplate">
        
    
    
    class="com.demo.spring.UserDaoImpl">
        
    
    

还有一个就是redis.properties了:

#最大分配的对象数  
redis.pool.maxActive=1024  
#最大能够保持idel状态的对象数  
redis.pool.maxIdle=200  
#当池内没有返回对象时,最大等待时间  
redis.pool.maxWait=1000  
#当调用borrow Object方法时,是否进行有效性检查  
redis.pool.testOnBorrow=true  
  
#IP  
redis.ip=127.0.0.1  
#Port  
redis.port=6379

好了,配置文件就是这些,也没什么特别之处。

2.编写一个User类:

public class User implements Serializable {
    /**
     * 
     */
    private static final long serialVersionUID = -1530813282496676263L;
    private Integer id;
    private String name;

    
    public Integer getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

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

}

3.编写一个userDao和UserDaoImpl

public interface UserDao {
    void save(User user);
    User read(User user);
    

}
public class UserDaoImpl implements UserDao {

    private RedisTemplate template;

    public RedisTemplate getTemplate() {
        return template;
    }

    public void setTemplate(RedisTemplate template) {
        this.template = template;
    }

    public User read(final User user) {
//        User user2 = (User) template.execute(new RedisCallback() {
//            @Override
//            public User doInRedis(RedisConnection connection)throws DataAccessException {
//                byte[] key = template.getStringSerializer().serialize("id"+user.getId());
//                if(connection.exists(key)){
//                    byte[] value = connection.get(key);
//                    String name = template.getStringSerializer().deserialize(value);
//                    User user1 = new User();
//                    user1.setName(name);
//                    return user1;
//                }
//                return null;
//            }
//        });
        ValueOperations opsForValue = template.opsForValue();
        User user2 = (User) opsForValue.get(user.getId());
        return user2;
        

    }

    public void save(final User user) {
//        template.execute(new RedisCallback() {
//            public Object doInRedis(RedisConnection connection) throws DataAccessException {
//                connection.set(template.getStringSerializer().serialize("id"+user.getId()), template.getStringSerializer().serialize(user.getName()));
//                return null;
//            }
//        });
        
        ValueOperations opsForValue = template.opsForValue();
        opsForValue.set(user.getId(), user);
    }

} 
    
   

这里注释部分是另一种方法,也是可以的,自定义对象需要序列化  template.getStringSerializer().serialize("xxx");

注释中connection方法很多例如:

connection.mGet(keys);//byte[]... keys
connection.mSet(tuple);//Map tuple
connection.lSet(key, index, value);//byte[] key, long index, byte[] value
connection.lRange(key, begin, end);//byte[] key, long begin, long end)等等

4.最后是测试类

private ApplicationContext app;
    private UserDao userDao;

    public UserDao getUserDao() {
        return userDao;
    }

    public void setUserDao(UserDao userDao) {
        this.userDao = userDao;
    }

    @Before
    public void before() throws Exception {
        app = new ClassPathXmlApplicationContext("applicationContext.xml");
     //得到userDao 对象 userDao
= (UserDao) app.getBean("userDao"); } @Test public void test1() { String name = "fu"; User user = new User(); user.setName(name); user.setId(1); userDao.save(user); System.out.println("============添加完成"); User u = userDao.read(user); System.out.println("============获取:" + u.getName()); }

 

哦了,基本的整合也就完成了。。

转载于:https://www.cnblogs.com/781811964-Fighter/p/4274010.html

你可能感兴趣的:(jedis与spring整合及简单的使用RedisTemplate操作)