SpringBoot Tair 实现数据缓存

543 阅读1分钟

Tair详细描述: Tair是一个Key/Value结构数据的解决方案,它默认支持基于内存和文件的两种存储方式,分别与缓存和持久化存储对应。Tari的功能是get、put、delete以及批量接口。 Tair中的每个数据都包含版本号,版本号在每次更新后都会递增。这个特性有助于防止由于数据的并发更新导致的问题。

直接看代码: pom.xml

   <!--tair缓存 会自带一个mina-core包:-->
        <dependency>
            <groupId>com.taobao.tair</groupId>
            <artifactId>tair-client</artifactId>
            <version>2.3.4</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

class类代码:

@Component
public class TairManager extends DefaultTairManager {
    @Value("${tair.servers}")
    private String servers;

    @Value("${tair.sysFix}")
    private String sysFix;

    @Value("${tair.group.name}")
    private String cacheGroupName;

    @Override
    @PostConstruct
    public void init() {
        String[] arr = servers.split(",");
        configServerList = Arrays.asList(arr);
        this.groupName = cacheGroupName;
        super.init();
    }
}

其实tair本身有put,get方法,但是为了更方便我们使用,可以进行相应的封装:

 /**
     * @param namespace  命名空间
     * @param key
     * @return
     */
    public <T> T getValue(int namespace, Serializable key) {
        Result<DataEntry> resultEntry = super.get(namespace, key);
        if (resultEntry.isSuccess()) {
            DataEntry dataEntry = resultEntry.getValue();
            return null != dataEntry ? (T) dataEntry.getValue() : null;
        }
        return null;
    }
     /**
     * @param namespace  命名空间
     * @param key,value
     * @version 版本号
     * @expireTime 失效时间
     * @return
     */
    public void putCache(int namespace, Serializable key, Serializable value,
                         int version, int expireTime){
        ResultCode resultCode  = super.put(namespace, key, value, version, expireTime);
        if(!resultCode.isSuccess()){
            throw new RuntimeException("putCache error...ResultCode:"+resultCode.getCode());
        }
    }
    /**
     * 指定名字空间的永久缓存
     * @param namespace
     * @param key
     * @param value
     * @失效时间为0,代表永久
     */
    public void putCache(int namespace, Serializable key, Serializable value) {
        putCache(namespace, key, value, 0, 0);
    }

使用的时候注解即可:

    @Autowired
    TairManager tairManager;

在工作中缓存是非常实用的,所以好好学起来吧!