@Test public void testPredefinedOptions() throws Exception { RocksDBStateBackend rocksDbBackend = new RocksDBStateBackend(TEMP_URI); assertEquals(PredefinedOptions.DEFAULT, rocksDbBackend.getPredefinedOptions()); rocksDbBackend.setPredefinedOptions(PredefinedOptions.SPINNING_DISK_OPTIMIZED); assertEquals(PredefinedOptions.SPINNING_DISK_OPTIMIZED, rocksDbBackend.getPredefinedOptions()); Options opt1 = rocksDbBackend.getRocksDBOptions(); Options opt2 = rocksDbBackend.getRocksDBOptions(); assertEquals(opt1, opt2); assertEquals(CompactionStyle.LEVEL, opt1.compactionStyle()); }
@Override public void init() throws DBException { System.out.println("Initializing RocksDB..."); String db_path = DB_PATH; options = new Options(); options .setCreateIfMissing(true) .createStatistics() .setWriteBufferSize(8 * SizeUnit.KB) .setMaxWriteBufferNumber(3) .setMaxBackgroundCompactions(10) .setCompressionType(CompressionType.SNAPPY_COMPRESSION) .setCompactionStyle(CompactionStyle.UNIVERSAL); Statistics stats = options.statisticsPtr(); assert (options.createIfMissing() == true); assert (options.writeBufferSize() == 8 * SizeUnit.KB); assert (options.maxWriteBufferNumber() == 3); assert (options.maxBackgroundCompactions() == 10); assert (options.compressionType() == CompressionType.SNAPPY_COMPRESSION); assert (options.compactionStyle() == CompactionStyle.UNIVERSAL); assert (options.memTableFactoryName().equals("SkipListFactory")); options.setMemTableConfig( new HashSkipListMemTableConfig() .setHeight(4) .setBranchingFactor(4) .setBucketCount(2000000)); assert (options.memTableFactoryName().equals("HashSkipListRepFactory")); options.setMemTableConfig(new HashLinkedListMemTableConfig().setBucketCount(100000)); assert (options.memTableFactoryName().equals("HashLinkedListRepFactory")); options.setMemTableConfig(new VectorMemTableConfig().setReservedSize(10000)); assert (options.memTableFactoryName().equals("VectorRepFactory")); options.setMemTableConfig(new SkipListMemTableConfig()); assert (options.memTableFactoryName().equals("SkipListFactory")); // options.setTableFormatConfig(new PlainTableConfig()); // // Plain-Table requires mmap read // options.setAllowMmapReads(true); // assert(options.tableFactoryName().equals("PlainTable")); // // options.setRateLimiterConfig(new GenericRateLimiterConfig(10000000, // 10000, 10)); // options.setRateLimiterConfig(new GenericRateLimiterConfig(10000000)); // // Filter bloomFilter = new BloomFilter(10); // BlockBasedTableConfig table_options = new BlockBasedTableConfig(); // table_options.setBlockCacheSize(64 * SizeUnit.KB) // .setFilter(bloomFilter) // .setCacheNumShardBits(6) // .setBlockSizeDeviation(5) // .setBlockRestartInterval(10) // .setCacheIndexAndFilterBlocks(true) // .setHashIndexAllowCollision(false) // .setBlockCacheCompressedSize(64 * SizeUnit.KB) // .setBlockCacheCompressedNumShardBits(10); // // assert(table_options.blockCacheSize() == 64 * SizeUnit.KB); // assert(table_options.cacheNumShardBits() == 6); // assert(table_options.blockSizeDeviation() == 5); // assert(table_options.blockRestartInterval() == 10); // assert(table_options.cacheIndexAndFilterBlocks() == true); // assert(table_options.hashIndexAllowCollision() == false); // assert(table_options.blockCacheCompressedSize() == 64 * SizeUnit.KB); // assert(table_options.blockCacheCompressedNumShardBits() == 10); // // options.setTableFormatConfig(table_options); // assert(options.tableFactoryName().equals("BlockBasedTable")); try { db = RocksDB.open(options, db_path); db.put("hello".getBytes(), "world".getBytes()); byte[] value = db.get("hello".getBytes()); assert ("world".equals(new String(value))); String str = db.getProperty("rocksdb.stats"); assert (str != null && str != ""); } catch (RocksDBException e) { System.out.format("[ERROR] caught the unexpceted exception -- %s\n", e); assert (db == null); assert (false); } System.out.println("Initializing RocksDB is over"); }