这两天主管让我给官网加上redis缓存因为原来打开页面太慢了,原来也没接触过redis所以花了两天走了不少弯路,为免忘记,在这记录一下。提醒一下这是我redis安装完成且配置了密码和服务为前提做的操作,没有安装redis的先安装redis。我也在另一篇写一下怎么安装redis吧。
首先要在项目中添加依赖jar包,我项目用的maven管理所以直接在pom里添加了如下代码,如果没用maven,jar包就要自己去下载。
网上大部分都只说要前两个jar包,但是我原来一直报错,后来找到说还要后两个jar包,项目完成后我试过删了后两个jar包启动立马报错……
接下来新建一个redis.properties文件保存配置参数,我的配置如下:
redis.host=localhost
redis.port=6379
redis.password=redis
redis.timeout=100000
redis.maxIdle=100
redis.maxActive=300
redis.maxWait=1000
redis.testOnBorrow=true
然后在applicationContext.xml文件中进行配置:
ignore-unresolvable="true"属性是我还读取了别的properties文件所以加的,而且另外那个读取properties文件的标签也要加这个属性。最后的RedisUtil是我建的工具类所以接下来建一个工具类RedisUtil,内容如下:
/**
* 操作redis缓存的工具类
* 部分方法未验证正确性
*/
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import java.util.concurrent.TimeUnit;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.stereotype.Component;
@Component
public final class RedisUtil {
@Autowired
private RedisTemplate
public void setRedisTemplate(RedisTemplate
this.redisTemplate = redisTemplate;
}
/**
* 写入缓存
*
* @param key
* @param value
* @return
*/
public boolean set(final String key, Object value) {
boolean result = false;
try {
ValueOperations
operations.set(key, value);
result = true;
} catch (Exception e) {
System.out.println("set cache error");
}
return result;
}
/**
* 读取缓存
*
* @param key
* @return
*/
public Object get(final String key) {
Object result = null;
ValueOperations
result = operations.get(key);
return result;
}
/**
* 删除对应的value
*
* @param key
*/
public void remove(final String key) {
if (exists(key)) {
redisTemplate.delete(key);
}
}
/**
* 批量读取缓存
* @param pattern
* @return
*/
public List
/**
* 模糊匹配批量删除key
*
* @param pattern
*/
public void removePattern(final String pattern) {
Set
if (keys.size() > 0)
redisTemplate.delete(keys);
}
/**
* 判断缓存中是否有对应的value
*
* @param key
* @return
*/
public boolean exists(final String key) {
return redisTemplate.hasKey(key);
}
/**
* 写入缓存(规定缓存时间)
*
* @param key
* @param value
* @return
*/
public boolean set(final String key, Object value, Long expireTime) {
boolean result = false;
try {
ValueOperations
operations.set(key, value);
redisTemplate.expire(key, expireTime, TimeUnit.SECONDS);
result = true;
} catch (Exception e) {
System.out.println("set cache error");
}
return result;
}
public long increment(final String key , long delta){
return redisTemplate.opsForValue().increment(key, delta);
}
}
我只用到了get();set();removePattern();其他方法没用到,不保证正确,你要用可以自己看着改。
之后就可以在要用redis缓存的地方用RedisUtil进行操作了。
比如我的一个用到redis缓存的方法如下:
@Autowired
private RedisUtil redisUtil;
public List
List
List
try {
//从缓存中读取数据
str = (List
} catch (Exception e) {
System.out.println("redis出错");
}
//缓存中若无要查找的数据则到数据库查找
if(str==null||str.isEmpty()) {
//从数据库查找数据
list_news=newsDao.getlist(news);
try {
//将数据库查找出的数据存入缓存,key为传入的参数以‘_’拼接而成
redisUtil.set(news.getPageSize()+"_"+news.getPageNum()+"_"+news.getTypeid()+"_"+news.getLangid(), list_news);
} catch (Exception e) {
System.out.println("redis出错");
}
}else {
list_news=str;
}
return list_news;
}
因为我要存到缓存的是List