/**
* 缓存操作实现类.
*/
@Service("cassCache")
public class CassCache implements ICassCache
{
/** 根据Key从缓存删除缓存数据.
* @param aKeyArea Key
*/
public void remove(String aKeyArea) throws ApplicationException
{
CassandraClientPool pool = CassandraClientPoolFactory.INSTANCE.get();
// 取得客户端(群集服务器)
CassandraClient client = null;
try
{
// 从群集服务器获得一个客户端
client = pool.borrowClient(mCassandraClient);
// Keyspace
Keyspace keyspace =
client.getKeyspace(mDefaultKeyspace);
// ColumnPath
ColumnPath columnPath = new ColumnPath(mDefaultColumnFamily);
// 从缓存中清除
keyspace.remove(aKeyArea, columnPath);
// 为确保finally中能正确释放client,此处需重获取一次
client = keyspace.getClient();
}
catch (Exception e)
{
sLog.error("根据Key从缓存删除缓存数据时出错。");
sLog.error(e);
throw new ApplicationException(e);
}
finally
{
// finally中释放client
releaseClient(pool, client);
}
}
/**根据Key和column从缓存删除缓存数据.
* @param aKeyArea Key
* @param aName column
*/
public void remove(String aKeyArea, String aName)
throws ApplicationException
{
CassandraClientPool pool = CassandraClientPoolFactory.INSTANCE.get();
// 取得客户端(群集服务器)
CassandraClient client = null;
try
{
// 从群集服务器获得一个客户端
client = pool.borrowClient(mCassandraClient);
// Keyspace
Keyspace keyspace =
client.getKeyspace(mDefaultKeyspace);
// ColumnPath
ColumnPath columnPath = new ColumnPath(mDefaultColumnFamily);
columnPath.setColumn(bytes(aName));
// 从缓存中清除
keyspace.remove(aKeyArea, columnPath);
// 为确保finally中能正确释放client,此处需重获取一次
client = keyspace.getClient();
}
catch (Exception e)
{
sLog.error("根据Key和column从缓存删除缓存数据时出错。");
sLog.error(e);
throw new ApplicationException(e);
}
finally
{
// finally中释放client
releaseClient(pool, client);
}
}
/** 根据属性名从绑定中取得属性值.
* @param aPropertyName 属性名
* @return 从绑定中取得的属性值
*/
public String getPropertyFromBinding(String aPropertyName)
throws ApplicationException
{
return CacheConfigReader.getInstance()
.getPropertyFromBinding(aPropertyName);
}
/** 释放client.
* @param aPool CassandraClientPool
* @param aClient Cassandra客户端
*/
private void releaseClient(CassandraClientPool aPool,
CassandraClient aClient)
throws ApplicationException
{
try
{
// 释放client
aPool.releaseClient(aClient);
}
catch (Exception e)
{
sLog.error("释放client时出错。");
sLog.error(e);
throw new ApplicationException(e);
}
}
}
分享到:
相关推荐
nosql 操作,cassandra添加删除操作代码
Cassandra PHP操作类,有使用实例,使用操作简单。
JAVA操作cassandra数据库,包括java代码及操作cassandra数据库总结文档。
Cassandra技术详解 操作与测试报告 基于nosql实现集群
还在为操作cassandara数据库没有界面而烦恼吗?这个小工具就是最后的选择,必须先装jdk哦
cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战cassandra 实战...
Cassandra的主要特点就是它不是一个数据库,而是由一堆数据库节点共同构成的一个分布式网络服务,对Cassandra 的一个写操作,会被复制到其他节点上去,对Cassandra的读操作,也会被路由到某个节点上面去读取。...
Cassandra 权限操作,grant/revoke
Cassandra的主要特点就是它不是一个数据库,而是由一堆数据库节点共同构成的一个分布式网络服务,对Cassandra 的一个写操作,会被复制到其他节点上去,对Cassandra的读操作,也会被路由到某个节点上面去读取。...
java导出cassandra数据
The rising popularity of Apache Cassandra rests on its ability to handle very large data sets that include hundreds of terabytes -- and that's why this distributed database has been chosen by ...
1、cassandra的安装、维护使用 2、java操作cassandra实例 3、cql使用详解
Cassandra文档
cassandra介绍
cassandra工具类DevCenter,比较好用,纯免费,比NoSqlManger好多了,版本DevCenter-1.6.0
DevCenter cassandra客户端 DevCenter cassandra客户端 DevCenter cassandra客户端
Cassandra(apache-cassandra-4.0.1-bin.tar.gz)是一套开源分布式NoSQL数据库系统。它最初由Facebook开发,用于储存收件箱等简单格式数据,集GoogleBigTable的数据模型与Amazon Dynamo的完全分布式的架构于一身...
cassandra
Cassandra实战.pdf
Cassandra查询分析器