jedis2.8.0的进一步封装:
1.序列化存储对象
2.结合spring,创建redis连接池
3.提供了基础的单个实体操作,有序list操作和一对多关系list的操作,对list提供了分页的封装
4.封装了简单的逻辑(如:重建缓存的场景,排序规则,具体方法需要重写~)
具体使用的时候,只需要继承符合你的业务的类(ICacheT,ICachtList,ICacheRelated),并重写下排序,重建时需要的具体数据等方法就可以啦
(1).单个缓存(ICacheT)
public class CachePerson extends CacheTBase<Integer,Person> { @Override
protected Person rebuild(Integer tkey) {
return null;
}
}
使用时:
Person p = new Person();
cachePerson.deleteByKey(Person.class,1,2);
cachePerson.get(Person.class, 1);
cachePerson.delete(p);
cachePerson.set(p);
(2).list缓存(ICachtList)
public class CacheCityList extends CacheListBase<City>{ @Override
protected String getKey() {
return "common:city";
} @Override
protected List<City> rebuildList() {
return null;
} @Override
protected List<City> rebuildPageList(Page page) {
return null;
} @Override
protected Double score(City item) {
return (double)item.getId();
}
}
使用时:
//批量list添加
list.addTioList(cityList);
//一个或多个添加
list.addToList(city1,city2);
//通过key删除
list.removeFromListByKey(City.class,"1","2","3","4","5");
//一个或多个删除
list.removeFromList(city1,city2);
//批量list删除
list.removeFromList(cityList);
//查找list
List<City> cityList = list.getList(City.class, true);
//查找带分页的list
List<City> cityList = list.getListPage(City.class, page, true);
//清空list
list.clearList();
(3).一对多关系(ICacheRelated)
public class CacheUserPersonList extends CacheRelatedBase<Person>{ @Override
protected String getKey(String mainkey) {
return null;
} @Override
protected List<Person> rebuildList(String mainkey) {
return null;
} @Override
protected List<Person> rebuildPageList(String mainkey, Page page) {
return null;
} @Override
protected double score(Person item) {
return 0;
}
}
使用时:
//添加
list.addRelated(person, "qiang");
//批量list添加方法
list.addRelateds("qiang", personList);
//添加一个或多个
list.addRelateds("qiang",p1,p2,p3,p4,p5);
//批量删除关系
list.removeRelated("qiang", personList);
//删除一个或多个关系
list.removeRelated("qiang", p1,p2,p3,p4,p5);
//根据id删除
list.removeFromListByKey("qiang", Person.class, "2","3");
//获取list,desc=true 为倒序(score 越大,排序越靠前~)
list.getRelatedList("qiang", desc)
//获取带分页的list,desc=true 为倒序
list.getRelatedListPage("qiang", page, desc);
//清空
list.clearList("qiang");
spring固定配置:
1.注入:
<?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:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd"> <!--序列化 -->
<bean id="iserializer" class="com.cjdz.test.cache.redis.JsonSerializer"></bean>
<!--缓存基本操作 -->
<bean id="redisCache" class="com.cjdz.test.cache.redis.RedisCache">
<property name="iserializer" ref="iserializer"></property>
</bean>
<bean id="cache" class="com.cjdz.test.cache.redis.RedisCache"></bean> <!-- 单个-->
<bean id="icacheT" class="com.cjdz.test.catchdata.impl.CacheTBase" abstract="true">
<property name="cache" ref="cache"></property>
</bean>
<!-- list-->
<bean id="icacheList" class="com.cjdz.test.catchdata.impl.CacheListBase" abstract="true">
<property name="cache" ref="cache"></property>
</bean>
<!-- 一对多-->
<bean id="icacheRelated" class="com.cjdz.test.catchdata.impl.CacheRelatedBase" abstract="true">
<property name="cache" ref="cache"></property>
</bean> <!-- 业务-->
<bean id="cacheCity" class="com.cjdz.test.catchdata.test.CacheCity" parent="icacheT"></bean>
<bean id="cachePerson" class="com.cjdz.test.catchdata.test.CachePerson" parent="icacheT"></bean>
<bean id="cacheCityList" class="com.cjdz.test.catchdata.test.CacheCityList" parent="icacheList"></bean>
<bean id="cacheUserPersonList" class="com.cjdz.test.catchdata.test.CacheUserPersonList" parent="icacheRelated"></bean> </beans>
2.连接池:
<?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" xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd"
default-lazy-init="true"> <description>Jedis Configuration</description> <!-- 加载配置属性文件 -->
<context:property-placeholder ignore-unresolvable="true" location="classpath:redis.properties" /> <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxIdle" value="300" /> <!-- 最大能够保持idel状态的对象数 -->
<property name="maxTotal" value="60000" /> <!-- 最大分配的对象数 -->
<property name="testOnBorrow" value="true" /> <!-- 当调用borrow Object方法时,是否进行有效性检查 -->
</bean> <bean id="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}" type="int" />
<constructor-arg index="3" value="${redis.timeout}" type="int" />
<constructor-arg index="4" value="${redis.auth}"/>
</bean>
</beans>
最后在RedisDesktop看到的大概是这样式滴:
这个是随便写的一个小东东,类似于helper吧,在使用时,既能规范开发时对缓存的操作,不至于最后缓存都乱掉,也能方便维护缓存。
有很多的局限性,写的时候,对象在redis中存储时,直接用了(对象类名:id) 的方式作为key,而list和related的key则交给开发者重写。之后慢慢改进吧 :)
文件地址:http://files.cnblogs.com/files/qiangweikang/reids-client.rar