本文整理汇总了Java中org.iq80.leveldb.CompressionType类的典型用法代码示例。如果您正苦于以下问题:Java CompressionType类的具体用法?Java CompressionType怎么用?Java CompressionType使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
CompressionType类属于org.iq80.leveldb包,在下文中一共展示了CompressionType类的12个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: start
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
private void start() throws IOException {
persister = Executors.newFixedThreadPool(config.getInt("persisterThreads"));
Options levelDbOptions = new Options();
levelDbOptions.createIfMissing(true);
levelDbOptions.cacheSize(config.getInt("levelDbCache"));
avatarDb = factory.open(new File("./db/chatAvatars"), levelDbOptions);
chatRoomDb = factory.open(new File("./db/chatRooms"), levelDbOptions);
if(config.getBoolean("compressMails"))
levelDbOptions.compressionType(CompressionType.SNAPPY);
mailDb = factory.open(new File("./db/mails"), levelDbOptions);
getHighestAvatarIdFromDatabase();
registrar = new ChatApiTcpListener(config.getInt("registrarPort"));
gateway = new ChatApiTcpListener(config.getInt("gatewayPort"));
registrar.start();
gateway.start();
}
示例2: open
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
@Override
public void open() {
Options options = new Options();
options.createIfMissing(true);
options.cacheSize(cacheSize);
options.compressionType(CompressionType.SNAPPY);
try {
File file = new File(database);
logger.info("Opening LevelDB: " + file.getAbsolutePath());
db = JniDBFactory.factory.open(new File(database), options);
logger.debug(db.getProperty("leveldb.stats"));
} catch (IOException e) {
logger.error("Error opening LevelDB ", e);
}
}
示例3: onOK
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
private void onOK() {
Options options = new Options();
options.createIfMissing(this.createBox.isSelected());
options.compressionType((CompressionType) this.compressType.getSelectedItem());
try{
options.maxOpenFiles(Integer.parseInt(this.maxOpenFiles.getValue().toString()));
}catch (NumberFormatException e){
options.maxOpenFiles(1000);
}
options.verifyChecksums(this.verifyChecksumsCheckBox.isSelected());
options.paranoidChecks(this.paranoidChecksCheckBox.isSelected());
this.viewer.setOptions(options);
dispose();
}
示例4: DainLevelDBStorageSystem
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
/** Constructor. */
public DainLevelDBStorageSystem(File dir, int cacheSizeMB)
throws StorageException {
ensureStorageDirectory(dir);
Options options = new Options();
options.createIfMissing(true);
// we disable compression, as the storage framework has own support for
// selective compression of sub-stores
options.compressionType(CompressionType.NONE);
options.cacheSize(cacheSizeMB * 1024 * 1024);
try {
database = Iq80DBFactory.factory.open(dir, options);
} catch (IOException e) {
throw new StorageException(e);
}
}
示例5: LevelDBJNI
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
/**
* @param config
* @throws IOException
*/
public LevelDBJNI(Config config) throws IOException {
super(config);
this.dbPath = config.getString("leveldb.path");
this.cacheSize = config.getBytes("leveldb.cache");
File dbDir = new File(dbPath);
if (!dbDir.exists()) {
if (!dbDir.mkdirs()) {
throw new IOException("Unable to create DB directory");
}
}
Options options = new Options();
options.createIfMissing(true);
options.cacheSize(cacheSize);
options.compressionType(CompressionType.NONE); // No compression
db = JniDBFactory.factory.open(dbDir, options);
}
示例6: connect
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
@Override
public void connect(Graph graph, Callback<Boolean> callback) {
if (isConnected) {
if (callback != null) {
callback.on(null);
}
return;
}
this.graph = graph;
//by default activate snappy compression of bytes
Options options = new Options()
.createIfMissing(true)
.compressionType(CompressionType.SNAPPY);
File location = new File(storagePath);
if (!location.exists()) {
location.mkdirs();
}
File targetDB = new File(location, "data");
targetDB.mkdirs();
try {
if (useNative) {
db = JniDBFactory.factory.open(targetDB, options);
} else {
db = Iq80DBFactory.factory.open(targetDB, options);
}
isConnected = true;
if (callback != null) {
callback.on(true);
}
} catch (Exception e) {
e.printStackTrace();
if (callback != null) {
callback.on(null);
}
}
}
示例7: start
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
public void start() {
if (getFile() == null) {
throw new IllegalArgumentException("A file must be configured");
}
if (LOG.isDebugEnabled()) {
LOG.debug("Starting LevelDB using file: {}", getFile());
}
Options options = new Options().writeBufferSize(writeBufferSize).maxOpenFiles(maxOpenFiles)
.blockRestartInterval(blockRestartInterval).blockSize(blockSize).verifyChecksums(verifyChecksums)
.paranoidChecks(paranoidChecks).cacheSize(cacheSize);
if ("snappy".equals(compressionType)) {
options.compressionType(CompressionType.SNAPPY);
} else {
options.compressionType(CompressionType.NONE);
}
options.createIfMissing(true);
try {
getFile().getParentFile().mkdirs();
db = factory.open(getFile(), options);
} catch (IOException ioe) {
throw new RuntimeException("Error opening LevelDB with file " + getFile(), ioe);
}
}
示例8: MCAFile2LevelDB
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
public MCAFile2LevelDB(File folderFrom, File folderTo) {
super(folderFrom, folderTo);
this.startTime = System.currentTimeMillis();
try {
if (!folderTo.exists()) {
folderTo.mkdirs();
}
String worldName = folderTo.getName();
try (PrintStream out = new PrintStream(new FileOutputStream(new File(folderTo, "levelname.txt")))) {
out.print(worldName);
}
this.pool = new ForkJoinPool();
this.remapper = new ClipboardRemapper(ClipboardRemapper.RemapPlatform.PC, ClipboardRemapper.RemapPlatform.PE);
BundledBlockData.getInstance().loadFromResource();
int bufferSize = (int) Math.min(Integer.MAX_VALUE, Math.max((long) (MemUtil.getFreeBytes() * 0.8), 134217728));
this.db = Iq80DBFactory.factory.open(new File(folderTo, "db"),
new Options()
.createIfMissing(true)
.verifyChecksums(false)
.compressionType(CompressionType.ZLIB)
.blockSize(262144) // 256K
.cacheSize(8388608) // 8MB
.writeBufferSize(134217728) // >=512MB
);
// try {
// this.db.suspendCompactions();
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
} catch (IOException e) {
throw new RuntimeException(e);
}
}
示例9: DatabaseImpl
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
public DatabaseImpl(String name) {
// Initialize Database
this.name = name;
Options options = new Options();
options.createIfMissing(true);
options.compressionType(CompressionType.NONE);
try {
logger.debug("Opening database");
File dbLocation = new File(System.getProperty("user.dir") + "/" +
SystemProperties.CONFIG.databaseDir() + "/");
File fileLocation = new File(dbLocation, name);
if(SystemProperties.CONFIG.databaseReset()) {
destroyDB(fileLocation);
}
logger.debug("Initializing new or existing database: '{}'", name);
db = factory.open(fileLocation, options);
// logger.debug("Showing database stats");
// String stats = DATABASE.getProperty("leveldb.stats");
// logger.debug(stats);
if (logger.isTraceEnabled()){
logger.trace("Dump for: {}", fileLocation.toString());
DBIterator iter = db.iterator();
while(iter.hasNext()){
byte[] key = iter.peekNext().getKey();
byte[] value = iter.peekNext().getValue();
logger.trace("key={}, value={}", Hex.toHexString(key), Hex.toHexString(value));
iter.next();
}
}
} catch (IOException ioe) {
logger.error(ioe.getMessage(), ioe);
throw new RuntimeException("Can't initialize database");
}
}
示例10: MapDatabase
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
/**
* Instantiates a new map database.
*
* @param basedir the basedir
* @throws MapDatabaseException the map database exception
* @throws MossWorldLoadException the moss world load exception
*/
@SuppressWarnings("nls")
public MapDatabase(File basedir) throws MapDatabaseException,
MossWorldLoadException {
File dbDir = new File(basedir, "db"); //$NON-NLS-1$
dbDir.mkdirs();
try {
Options options = new Options();
options.paranoidChecks(false); // ACHTUNG! Corrption!
options.verifyChecksums(true); // for now to help control the corruption
options.blockSize(8192); // Chunks are kind of big
options.compressionType(CompressionType.SNAPPY);
//options.comparator(null);
this.map = factory.open(new File(dbDir, "map"), options); //$NON-NLS-1$
this.mapHeavies = factory.open(new File(dbDir, "mapHeavies"), //$NON-NLS-1$
options);
options.blockSize(4096); // Nothing is really big after this point.
this.entities = factory.open(new File(dbDir, "entities"), options); //$NON-NLS-1$
this.metadata = factory.open(new File(dbDir, "metadata"), options); //$NON-NLS-1$
this.players = factory.open(new File(dbDir, "players"), options); //$NON-NLS-1$
this.nodes = factory.open(new File(dbDir, "nodes"), options); //$NON-NLS-1$
} catch (IOException e) {
logger.error(MessageFormat.format(Messages.getString("DB_LOAD_IOEXCEPTION"), e.getMessage()));
throw new MossWorldLoadException(Messages.getString("MapDatabase.ERR_DB_FAIL"), e); //$NON-NLS-1$
}
logger.info(Messages.getString("DB_NORMAL_LOAD"));
}
示例11: dataDbOptions
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
private Options dataDbOptions() {
Options options = new Options().createIfMissing(true);
options.compressionType(CompressionType.valueOf(configuration.compressionType().name()));
if (configuration.blockSize() != null) {
options.blockSize(configuration.blockSize());
}
if (configuration.cacheSize() != null) {
options.cacheSize(configuration.cacheSize());
}
return options;
}
示例12: activateService
import org.iq80.leveldb.CompressionType; //导入依赖的package包/类
@Override
public void activateService()
throws Exception
{
charset = Charset.forName( "UTF-8" );
configuration.refresh();
LevelDBEntityStoreConfiguration config = configuration.get();
// Choose flavour
String flavour = config.flavour().get();
DBFactory factory;
if( "jni".equalsIgnoreCase( flavour ) )
{
factory = newJniDBFactory();
}
else if( "java".equalsIgnoreCase( flavour ) )
{
factory = newJavaDBFactory();
}
else
{
factory = newDBFactory();
}
// Apply configuration
Options options = new Options();
options.createIfMissing( true );
if( config.blockRestartInterval().get() != null )
{
options.blockRestartInterval( config.blockRestartInterval().get() );
}
if( config.blockSize().get() != null )
{
options.blockSize( config.blockSize().get() );
}
if( config.cacheSize().get() != null )
{
options.cacheSize( config.cacheSize().get() );
}
if( config.compression().get() != null )
{
options.compressionType( config.compression().get()
? CompressionType.SNAPPY
: CompressionType.NONE );
}
if( config.maxOpenFiles().get() != null )
{
options.maxOpenFiles( config.maxOpenFiles().get() );
}
if( config.paranoidChecks().get() != null )
{
options.paranoidChecks( config.paranoidChecks().get() );
}
if( config.verifyChecksums().get() != null )
{
options.verifyChecksums( config.verifyChecksums().get() );
}
if( config.writeBufferSize().get() != null )
{
options.writeBufferSize( config.writeBufferSize().get() );
}
if( config.errorIfExists().get() != null )
{
options.errorIfExists( config.errorIfExists().get() );
}
// Open/Create the database
File dbFile = new File( fileConfig.dataDirectory(), descriptor.identity().toString() );
db = factory.open( dbFile, options );
}