com.hmsonline.cassandra.triggers.CassandraStore Maven / Gradle / Ivy
package com.hmsonline.cassandra.triggers;
import java.util.ArrayList;
import java.util.List;
import org.apache.cassandra.thrift.Cassandra;
import org.apache.cassandra.thrift.CassandraServer;
import org.apache.cassandra.thrift.CfDef;
import org.apache.cassandra.thrift.KsDef;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class CassandraStore {
private static Logger logger = LoggerFactory.getLogger(CassandraStore.class);
private static boolean initialized = false;
private String keyspace = null;
private String columnFamily = null;
protected CassandraStore(String keyspace, String columnFamily) throws Exception {
this.keyspace = keyspace;
this.columnFamily = columnFamily;
this.create();
}
Cassandra.Iface getConnection(String keyspace) throws Exception {
CassandraServer server = new CassandraServer();
if (keyspace != null) {
server.set_keyspace(keyspace);
}
return server;
}
public synchronized void create() throws Exception {
if (!initialized) {
try {
List cfDefList = new ArrayList();
KsDef ksDef = new KsDef(this.getKeyspace(), "org.apache.cassandra.locator.SimpleStrategy", cfDefList);
ksDef.putToStrategy_options("replication_factor", "1");
getConnection(null).system_add_keyspace(ksDef);
} catch (Exception e) {
logger.debug("Did not create [" + this.getKeyspace() + ":" + this.getColumnFamily()
+ "] (probably already there)");
}
try {
CfDef columnFamily = new CfDef(this.getKeyspace(), this.getColumnFamily());
columnFamily.setKey_validation_class("UTF8Type");
columnFamily.setDefault_validation_class("UTF8Type");
columnFamily.setComparator_type("UTF8Type");
getConnection(this.getKeyspace()).system_add_column_family(columnFamily);
initialized = true;
} catch (Exception e) {
logger.debug("Did not create [" + this.getKeyspace() + ":" + this.getColumnFamily()
+ "] (probably already there)");
}
}
}
public String getKeyspace() {
return keyspace;
}
public void setKeyspace(String keyspace) {
this.keyspace = keyspace;
}
public String getColumnFamily() {
return columnFamily;
}
public void setColumnFamily(String columnFamily) {
this.columnFamily = columnFamily;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy