use of com.sleepycat.je.Environment in project sessdb by ppdai.
the class BdbBenchmark method open.
@Override
public void open() {
try {
EnvironmentConfig envConfig = new EnvironmentConfig();
envConfig.setAllowCreate(true);
envConfig.setCachePercent(90);
File file = new File(databaseDir_);
if (!file.exists()) {
file.mkdirs();
}
env_ = new Environment(file, envConfig);
DatabaseConfig dbConfig = new DatabaseConfig();
dbConfig.setAllowCreate(true);
bdb_ = env_.openDatabase(null, BdbBenchmark.DATABASE_NAME, dbConfig);
} catch (DatabaseException e) {
e.printStackTrace();
}
}
use of com.sleepycat.je.Environment in project GeoGig by boundlessgeo.
the class EnvironmentBuilder method get.
/**
* @return
* @see com.google.inject.Provider#get()
*/
@Override
public synchronized Environment get() {
final Optional<URL> repoUrl = new ResolveGeogigDir(platform).call();
if (!repoUrl.isPresent() && absolutePath == null) {
throw new IllegalStateException("Can't find geogig repository home");
}
final File storeDirectory;
if (absolutePath != null) {
storeDirectory = absolutePath;
} else {
File currDir;
try {
currDir = new File(repoUrl.get().toURI());
} catch (URISyntaxException e) {
throw Throwables.propagate(e);
}
File dir = currDir;
for (String subdir : path) {
dir = new File(dir, subdir);
}
storeDirectory = dir;
}
if (!storeDirectory.exists() && !storeDirectory.mkdirs()) {
throw new IllegalStateException("Unable to create Environment directory: '" + storeDirectory.getAbsolutePath() + "'");
}
EnvironmentConfig envCfg;
if (this.forceConfig == null) {
File conf = new File(storeDirectory, "je.properties");
if (!conf.exists()) {
String resource = stagingDatabase ? "je.properties.staging" : "je.properties.objectdb";
ByteSource from = Resources.asByteSource((getClass().getResource(resource)));
try {
from.copyTo(Files.asByteSink(conf));
} catch (IOException e) {
Throwables.propagate(e);
}
}
// use the default settings
envCfg = new EnvironmentConfig();
envCfg.setAllowCreate(true);
envCfg.setCacheMode(CacheMode.MAKE_COLD);
envCfg.setLockTimeout(5, TimeUnit.SECONDS);
envCfg.setDurability(Durability.COMMIT_SYNC);
// envCfg.setReadOnly(readOnly);
} else {
envCfg = this.forceConfig;
}
// // envCfg.setSharedCache(true);
// //
// final boolean transactional = false;
// envCfg.setTransactional(transactional);
// envCfg.setCachePercent(75);// Use up to 50% of the heap size for the shared db cache
// envCfg.setConfigParam(EnvironmentConfig.LOG_FILE_MAX, String.valueOf(256 * 1024 * 1024));
// // check <http://www.oracle.com/technetwork/database/berkeleydb/je-faq-096044.html#35>
// envCfg.setConfigParam("je.evictor.lruOnly", "false");
// envCfg.setConfigParam("je.evictor.nodesPerScan", "100");
//
// envCfg.setConfigParam(EnvironmentConfig.CLEANER_MIN_UTILIZATION, "25");
// envCfg.setConfigParam(EnvironmentConfig.CHECKPOINTER_HIGH_PRIORITY, "true");
//
// envCfg.setConfigParam(EnvironmentConfig.CLEANER_THREADS, "4");
// // TODO: check whether we can set is locking to false
// envCfg.setConfigParam(EnvironmentConfig.ENV_IS_LOCKING, String.valueOf(transactional));
//
// envCfg.setConfigParam(EnvironmentConfig.ENV_RUN_CHECKPOINTER,
// String.valueOf(!transactional));
// envCfg.setConfigParam(EnvironmentConfig.ENV_RUN_CLEANER, String.valueOf(!transactional));
//
// // envCfg.setConfigParam(EnvironmentConfig.ENV_RUN_EVICTOR, "false");
Environment env;
try {
env = new Environment(storeDirectory, envCfg);
} catch (RuntimeException lockedEx) {
// lockedEx.printStackTrace();
if (readOnly) {
// this happens when trying to open the env in read only mode when its already open
// in read/write mode inside the same process. So we re-open it read-write but the
// database itself will be open read-only by JEObjectDatabase.
envCfg.setReadOnly(true);
env = new Environment(storeDirectory, envCfg);
} else {
throw lockedEx;
}
}
return env;
}
use of com.sleepycat.je.Environment in project sirix by sirixdb.
the class BerkeleyStorageFactory method createStorage.
/**
* Create a new storage.
*
* @param resourceConfig the resource configuration
* @return the berkeley DB storage
* @throws NullPointerException if {@link ResourceConfiguration} is {@code null}
* @throws SirixIOException if the storage couldn't be created because of an I/O exception
*/
public BerkeleyStorage createStorage(final ResourceConfiguration resourceConfig) {
try {
final Path repoFile = resourceConfig.mPath.resolve(ResourceConfiguration.ResourcePaths.DATA.getFile());
if (!Files.exists(repoFile)) {
Files.createDirectories(repoFile);
}
final ByteHandlePipeline byteHandler = checkNotNull(resourceConfig.mByteHandler);
final DatabaseConfig conf = generateDBConf();
final EnvironmentConfig config = generateEnvConf();
final List<Path> path;
try (final Stream<Path> stream = Files.list(repoFile)) {
path = stream.collect(toList());
}
if (path.isEmpty() || (path.size() == 1 && "sirix.data".equals(path.get(0).getFileName().toString()))) {
conf.setAllowCreate(true);
config.setAllowCreate(true);
}
final Environment env = new Environment(repoFile.toFile(), config);
final Database database = env.openDatabase(null, NAME, conf);
return new BerkeleyStorage(env, database, byteHandler);
} catch (final DatabaseException | IOException e) {
throw new SirixIOException(e);
}
}
use of com.sleepycat.je.Environment in project leopard by tanhaichao.
the class BdbImpl method init.
public void init() throws EnvironmentLockedException, DatabaseException {
EnvironmentConfig environmentConfig = new EnvironmentConfig();
DatabaseConfig dbConfig = new DatabaseConfig();
dbConfig.setAllowCreate(true);
dbConfig.setSortedDuplicates(true);
environmentConfig.setReadOnly(false);
environmentConfig.setAllowCreate(true);
// Open the environment and entity store
if (!dataDir.exists()) {
dataDir.mkdirs();
}
environment = new Environment(dataDir, environmentConfig);
// Database database = environment.openDatabase(transaction, "BDB", dbConfig);
this.bdb = new BdbDatabaseImpl(environment, "DEFAULT");
}
use of com.sleepycat.je.Environment in project voldemort by voldemort.
the class BdbStorageConfiguration method adjustCacheSizes.
/**
* When a reservation is made, we need to shrink the shared cache
* accordingly to guarantee memory foot print of the new store. NOTE: This
* is not an instantaneous operation. Changes will take effect only when
* traffic is thrown and eviction happens.( Won't happen until Network ports
* are opened anyway which is rightfully done after storage service).When
* changing this dynamically, we might want to block until the shared cache
* shrinks enough
*/
private void adjustCacheSizes() {
long newSharedCacheSize = voldemortConfig.getBdbCacheSize() - this.reservedCacheSize;
logger.info("Setting the shared cache size to " + newSharedCacheSize);
for (Environment environment : unreservedStores) {
EnvironmentMutableConfig mConfig = environment.getMutableConfig();
mConfig.setCacheSize(newSharedCacheSize);
environment.setMutableConfig(mConfig);
}
}
Aggregations