JetCache快速入门

640?wx_fmt=gif&wxfrom=5&wx_lazy=1

本文简要介绍了基于注解来配置使用JetCache的方式。当使用JetCache的注解时,可以搭配Spring4.0.8以上版本,或者Spring Boot 1.1.9以上版本,本文同时展示了这两种情况下的配置方式。如果不需要使用注解,也可以。

创建缓存实例

通过@CreateCache注解创建一个缓存实例,默认超时时间是100秒

@CreateCache(expire = 100)
private Cache<Long, UserDO> userCache;

用起来就像map一样

UserDO user = userCache.get(123L);
userCache.put(123L, user);
userCache.remove(123L);

创建一个两级(内存+远程)的缓存,内存中的元素个数限制在50个。

@CreateCache(name = "UserService.userCache", expire = 100, cacheType = CacheType.BOTH, localLimit = 50)
private Cache<Long, UserDO> userCache;

name属性不是必须的,但是起个名字是个好习惯,展示统计数据的使用,会使用这个名字。如果同一个area两个@CreateCache的name配置一样,它们生成的Cache将指向同一个实例。

创建方法缓存

使用@Cached方法可以为一个方法添加上缓存。JetCache通过Spring AOP生成代理,来支持缓存功能。注解可以加在接口方法上也可以加在类方法上,但需要保证是个Spring bean。

public interface UserService {
   @Cached(name="UserService.getUserById", expire = 3600)
   User getUserById(long userId);
}

基本配置(使用Spring Boot)

如果使用Spring Boot,可以按如下的方式配置。

POM

<dependency>
   <groupId>com.alicp.jetcache</groupId>
   <artifactId>jetcache-starter-redis</artifactId>
   <version>2.4.4</version>
</dependency>

配置一个spring boot风格的application.yml文件,把他放到资源目录中

jetcache:
 statIntervalMinutes: 15
 areaInCacheName: false
 local:
   default:
     type: linkedhashmap
     keyConvertor: fastjson
 remote:
   default:
     type: redis
     keyConvertor: fastjson
     valueEncoder: java
     valueDecoder: java
     poolConfig:
       minIdle: 5
       maxIdle: 20
       maxTotal: 50
     host: 127.0.0.1
     port: 6379

然后创建一个App类放在业务包的根下,EnableMethodCache,EnableCreateCacheAnnotation这两个注解分别激活Cached和CreateCache注解,其他和标准的Spring Boot程序是一样的。这个类可以直接main方法运行。

package com.company.mypackage;

import com.alicp.jetcache.anno.config.EnableCreateCacheAnnotation;
import com.alicp.jetcache.anno.config.EnableMethodCache;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@EnableMethodCache(basePackages = "com.company.mypackage")
@EnableCreateCacheAnnotation
public class MySpringBootApp {
   public static void main(String[] args) {
       SpringApplication.run(MySpringBootApp.class);
   }
}

未使用SpringBoot的配置方式

如果没有使用spring boot,可以按下面的方式配置(这里使用jedis客户端连接redis为例)。

<dependency>
   <groupId>com.alicp.jetcache</groupId>
   <artifactId>jetcache-anno</artifactId>
   <version>2.4.4</version>
</dependency>
<dependency>
   <groupId>com.alicp.jetcache</groupId>
   <artifactId>jetcache-redis</artifactId>
   <version>2.4.4</version>
</dependency>

配置了这个JetCacheConfig类以后,可以使用@CreateCache和@Cached注解。

package com.company.mypackage;

import java.util.HashMap;
import java.util.Map;

import com.alicp.jetcache.anno.CacheConsts;
import com.alicp.jetcache.anno.config.EnableCreateCacheAnnotation;
import com.alicp.jetcache.anno.config.EnableMethodCache;
import com.alicp.jetcache.anno.support.GlobalCacheConfig;
import com.alicp.jetcache.anno.support.SpringConfigProvider;
import com.alicp.jetcache.embedded.EmbeddedCacheBuilder;
import com.alicp.jetcache.embedded.LinkedHashMapCacheBuilder;
import com.alicp.jetcache.redis.RedisCacheBuilder;
import com.alicp.jetcache.support.FastjsonKeyConvertor;
import com.alicp.jetcache.support.JavaValueDecoder;
import com.alicp.jetcache.support.JavaValueEncoder;
import org.apache.commons.pool2.impl.GenericObjectPoolConfig;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.util.Pool;

@Configuration
@EnableMethodCache(basePackages = "com.company.mypackage")
@EnableCreateCacheAnnotation
public class JetCacheConfig {

   @Bean
   public Pool<Jedis> pool(){
       GenericObjectPoolConfig pc = new GenericObjectPoolConfig();
       pc.setMinIdle(2);
       pc.setMaxIdle(10);
       pc.setMaxTotal(10);
       return new JedisPool(pc, "localhost", 6379);
   }

   @Bean
   public SpringConfigProvider springConfigProvider() {
       return new SpringConfigProvider();
   }

   @Bean
   public GlobalCacheConfig config(SpringConfigProvider configProvider, Pool<Jedis> pool){
       Map localBuilders = new HashMap();
       EmbeddedCacheBuilder localBuilder = LinkedHashMapCacheBuilder
               .createLinkedHashMapCacheBuilder()
               .keyConvertor(FastjsonKeyConvertor.INSTANCE);
       localBuilders.put(CacheConsts.DEFAULT_AREA, localBuilder);

       Map remoteBuilders = new HashMap();
       RedisCacheBuilder remoteCacheBuilder = RedisCacheBuilder.createRedisCacheBuilder()
               .keyConvertor(FastjsonKeyConvertor.INSTANCE)
               .valueEncoder(JavaValueEncoder.INSTANCE)
               .valueDecoder(JavaValueDecoder.INSTANCE)
               .jedisPool(pool);
       remoteBuilders.put(CacheConsts.DEFAULT_AREA, remoteCacheBuilder);

       GlobalCacheConfig globalCacheConfig = new GlobalCacheConfig();
       globalCacheConfig.setConfigProvider(configProvider);
       globalCacheConfig.setLocalCacheBuilders(localBuilders);
       globalCacheConfig.setRemoteCacheBuilders(remoteBuilders);
       globalCacheConfig.setStatIntervalMinutes(15);
       globalCacheConfig.setAreaInCacheName(false);

       return globalCacheConfig;
   }
}

进一步阅读

  • CreateCache的详细使用说明可以看这里

  • 使用@CacheCache创建的Cache接口实例,它的API使用可以看这里

  • 关于方法缓存(@Cached, @CacheUpdate, @CacheInvalidate)的详细使用看这里

  • 详细的配置说明看这里

  • (全文完)

  • 640?wx_fmt=gif

640?wx_fmt=jpeg


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值