Java Code Examples for org.rocksdb.BlockBasedTableConfig#setFilterPolicy()
The following examples show how to use
org.rocksdb.BlockBasedTableConfig#setFilterPolicy() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: RocksDBWrapper.java From aion with MIT License | 5 votes |
private BlockBasedTableConfig setupBlockBasedTableConfig() { BlockBasedTableConfig bbtc = new BlockBasedTableConfig(); bbtc.setBlockSize(BLOCK_SIZE); bbtc.setCacheIndexAndFilterBlocks(true); bbtc.setPinL0FilterAndIndexBlocksInCache(true); bbtc.setFilterPolicy(new BloomFilter(BLOOMFILTER_BITS_PER_KEY, false)); return bbtc; }
Example 2
Source File: RocksDBConfigParser.java From journalkeeper with Apache License 2.0 | 4 votes |
public static Options parse(Properties properties) { Options options = new Options(); options.setCompressionType(CompressionType.LZ4_COMPRESSION) .setCompactionStyle(CompactionStyle.LEVEL); BlockBasedTableConfig tableOptions = new BlockBasedTableConfig(); options.setTableFormatConfig(tableOptions); for (String key : properties.stringPropertyNames()) { String prefix = null; Object configInstance = null; if (key.startsWith(RocksDBConfigs.OPTIONS_PREFIX)) { prefix = RocksDBConfigs.OPTIONS_PREFIX; configInstance = options; } else if (key.startsWith(RocksDBConfigs.TABLE_OPTIONS_PREFIX)) { prefix = RocksDBConfigs.TABLE_OPTIONS_PREFIX; configInstance = tableOptions; } else { continue; } String fieldKey = key.substring(prefix.length(), key.length()); String value = properties.getProperty(key); try { Method setterMethod = findSetterMethod(configInstance.getClass(), fieldKey); if (setterMethod == null) { logger.warn("parse config error, method not found, key: {}, value: {}", key, value); continue; } setterMethod.invoke(configInstance, PropertyUtils.convert(value, setterMethod.getParameters()[0].getType())); } catch (Exception e) { logger.error("parse config error, key: {}, value: {}", key, value, e); } } if (properties.containsKey(RocksDBConfigs.FILTER_BITSPER_KEY)) { tableOptions.setFilterPolicy(new BloomFilter( PropertyUtils.convertInt(properties.getProperty(RocksDBConfigs.FILTER_BITSPER_KEY), 0))); } return options; }
Example 3
Source File: RocksDBCache.java From kcache with Apache License 2.0 | 4 votes |
private void openDB() { // initialize the default rocksdb options final DBOptions dbOptions = new DBOptions(); final ColumnFamilyOptions columnFamilyOptions = new ColumnFamilyOptions(); userSpecifiedOptions = new RocksDBGenericOptionsToDbOptionsColumnFamilyOptionsAdapter(dbOptions, columnFamilyOptions); userSpecifiedOptions.setComparator(new RocksDBKeySliceComparator<>(keySerde, comparator)); final BlockBasedTableConfig tableConfig = new BlockBasedTableConfig(); cache = new LRUCache(BLOCK_CACHE_SIZE); tableConfig.setBlockCache(cache); tableConfig.setBlockSize(BLOCK_SIZE); filter = new BloomFilter(); tableConfig.setFilterPolicy(filter); userSpecifiedOptions.optimizeFiltersForHits(); userSpecifiedOptions.setTableFormatConfig(tableConfig); userSpecifiedOptions.setWriteBufferSize(WRITE_BUFFER_SIZE); userSpecifiedOptions.setCompressionType(COMPRESSION_TYPE); userSpecifiedOptions.setCompactionStyle(COMPACTION_STYLE); userSpecifiedOptions.setMaxWriteBufferNumber(MAX_WRITE_BUFFERS); userSpecifiedOptions.setCreateIfMissing(true); userSpecifiedOptions.setErrorIfExists(false); userSpecifiedOptions.setInfoLogLevel(InfoLogLevel.ERROR_LEVEL); // this is the recommended way to increase parallelism in RocksDb // note that the current implementation of setIncreaseParallelism affects the number // of compaction threads but not flush threads (the latter remains one). Also // the parallelism value needs to be at least two because of the code in // https://github.com/facebook/rocksdb/blob/62ad0a9b19f0be4cefa70b6b32876e764b7f3c11/util/options.cc#L580 // subtracts one from the value passed to determine the number of compaction threads // (this could be a bug in the RocksDB code and their devs have been contacted). userSpecifiedOptions.setIncreaseParallelism(Math.max(Runtime.getRuntime().availableProcessors(), 2)); wOptions = new WriteOptions(); wOptions.setDisableWAL(true); fOptions = new FlushOptions(); fOptions.setWaitForFlush(true); dbDir = new File(new File(rootDir, parentDir), name); try { Files.createDirectories(dbDir.getParentFile().toPath()); Files.createDirectories(dbDir.getAbsoluteFile().toPath()); } catch (final IOException fatal) { throw new CacheInitializationException("Could not create directories", fatal); } openRocksDB(dbOptions, columnFamilyOptions); open = true; }