java使用redis緩存能夠使用jedis框架,jedis操做簡單,沒有什麼複雜的東西須要學習,網上資料不少,隨便看看就會了.html
將spring與redis緩存集成,其實也是使用jedis框架,只不過spring對它進行了一層封裝,並將這層封裝庫命名爲spring-data-redis.java
下面將要使用spring-data-redis與jedis的jar包,並經過spring的aop功能,將redis緩存無縫無侵入的整合進來.redis
1.先下載好依賴包spring
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-core</artifactId>
- <version>4.1.1.RELEASE</version>
- </dependency>
- <dependency>
- <groupId>org.springframework.data</groupId>
- <artifactId>spring-data-redis</artifactId>
- <version>1.4.1.RELEASE</version>
- </dependency>
- <dependency>
- <groupId>redis.clients</groupId>
- <artifactId>jedis</artifactId>
- <version>2.6.0</version>
- </dependency>
2.再配置spring文件後端
- <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
- <property name="minIdle" value="${redis.minIdle}" />
- <property name="maxIdle" value="${redis.maxIdle}" />
- <property name="maxTotal" value="${redis.maxActive}" />
- <property name="maxWaitMillis" value="${redis.maxWait}" />
- <property name="testOnBorrow" value="${redis.testOnBorrow}" />
- </bean>
-
- <bean id="jedisConnFactory" 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="usePool" value="true" />
- <property name="poolConfig" ref="poolConfig" />
- </bean>
-
- <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
- <property name="connectionFactory" ref="jedisConnFactory" />
- <property name="keySerializer">
- <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
- </property>
- <property name="valueSerializer">
- <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
- </property>
- <property name="hashKeySerializer">
- <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
- </property>
- <property name="hashValueSerializer">
- <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/>
- </property>
- </bean>
3.開始編寫aop代碼緩存
3.1 聲明兩個註解類,用於定義哪些方法將使用緩存app
- @Retention(RetentionPolicy.RUNTIME)
- @Target({ElementType.METHOD})
- public @interface Cacheable {
-
- public enum KeyMode{
- DEFAULT,
- BASIC,
- ALL;
- }
-
- public String key() default "";
- public KeyMode keyMode() default KeyMode.DEFAULT;
- public int expire() default 0;
- }
- @Retention(RetentionPolicy.RUNTIME)
- @Target({ElementType.PARAMETER})
- public @interface CacheKey {}
3.2 建立一個Aop攔截器的處理類,用於攔截加了@Cacheable的方法框架
- @Aspect
- @Component
- public class CacheableAop {
-
- @Autowired private RedisTemplate redisTemplate;
-
- @Around("@annotation(cache)")
- public Object cached(final ProceedingJoinPoint pjp,Cacheable cache) throws Throwable {
-
- String key=getCacheKey(pjp, cache);
- ValueOperations<String, Object> valueOper=redisTemplate.opsForValue();
- Object value=valueOper.get(key);
- if(value!=null) return value;
-
- value = pjp.proceed();
- if(cache.expire()<=0) {
- valueOper.set(key, value);
- } else {
- valueOper.set(key, value,cache.expire(),TimeUnit.SECONDS);
- }
- return value;
- }
-
-
- private String getCacheKey(ProceedingJoinPoint pjp,Cacheable cache) {
-
- StringBuilder buf=new StringBuilder();
- buf.append(pjp.getSignature().getDeclaringTypeName()).append(".").append(pjp.getSignature().getName());
- if(cache.key().length()>0) {
- buf.append(".").append(cache.key());
- }
-
- Object[] args=pjp.getArgs();
- if(cache.keyMode()==KeyMode.DEFAULT) {
- Annotation[][] pas=((MethodSignature)pjp.getSignature()).getMethod().getParameterAnnotations();
- for(int i=0;i<pas.length;i++) {
- for(Annotation an:pas[i]) {
- if(an instanceof CacheKey) {
- buf.append(".").append(args[i].toString());
- break;
- }
- }
- }
- } else if(cache.keyMode()==KeyMode.BASIC) {
- for(Object arg:args) {
- if(arg instanceof String) {
- buf.append(".").append(arg);
- } else if(arg instanceof Integer || arg instanceof Long || arg instanceof Short) {
- buf.append(".").append(arg.toString());
- } else if(arg instanceof Boolean) {
- buf.append(".").append(arg.toString());
- }
- }
- } else if(cache.keyMode()==KeyMode.ALL) {
- for(Object arg:args) {
- buf.append(".").append(arg.toString());
- }
- }
-
- return buf.toString();
- }
- }
4.使用緩存示例學習
- @Service
- @Transactional
- public class DemoServiceImpl implements DemoService {
-
- @Autowired private DemoDao demoDao;
-
- public List<Demo> findAll() {
- return demoDao.findAll();
- }
-
-
- @Cacheable(expire=3600)
- public Demo get(@CacheKey String id) {
- return demoDao.get(id);
- }
-
- public Demo getByName(String name) {
- return demoDao.getByName(name);
- }
- }
- 若爲名稱相同的方法配置緩存,能夠在@Cacheable中加入key屬性,追加額外的key後綴
- @Cacheable還有一個KeyMode屬性,用於配置哪些參數能夠追加到key後綴中,
默認取值 DEFAULT:表示只有加了@CacheKey的參數才能追加到key後綴
BASIC:自動將基本類型追加到key後綴,而無需再配置@CacheKey
ALL:自動將全部參數追加到lkey後綴,而無需再配置@CacheKey
這只是一個初步整合方案,測試可行,還未在生產中使用,實際效果待驗正.測試