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;
在工作中缓存是非常实用的,所以好好学起来吧!