/* * * * Copyright 2014 Orient Technologies LTD (info(at)orientechnologies.com) * * * * Licensed under the Apache License, Version 2.0 (the "License"); * * you may not use this file except in compliance with the License. * * You may obtain a copy of the License at * * * * http://www.apache.org/licenses/LICENSE-2.0 * * * * Unless required by applicable law or agreed to in writing, software * * distributed under the License is distributed on an "AS IS" BASIS, * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * * See the License for the specific language governing permissions and * * limitations under the License. * * * * For more information: http://www.orientechnologies.com * */ package com.orientechnologies.orient.core.engine.local; import com.orientechnologies.common.collection.closabledictionary.OClosableLinkedContainer; import com.orientechnologies.common.directmemory.OByteBufferPool; import com.orientechnologies.common.exception.OException; import com.orientechnologies.common.io.OIOUtils; import com.orientechnologies.common.log.OLogManager; import com.orientechnologies.orient.core.config.OGlobalConfiguration; import com.orientechnologies.orient.core.engine.OEngineAbstract; import com.orientechnologies.orient.core.engine.OMemoryAndLocalPaginatedEnginesInitializer; import com.orientechnologies.orient.core.exception.ODatabaseException; import com.orientechnologies.orient.core.storage.OStorage; import com.orientechnologies.orient.core.storage.cache.local.twoq.O2QCache; import com.orientechnologies.orient.core.storage.fs.OFileClassic; import com.orientechnologies.orient.core.storage.impl.local.paginated.OLocalPaginatedStorage; import java.util.Map; /** * @author Andrey Lomakin * @since 28.03.13 */ public class OEngineLocalPaginated extends OEngineAbstract { public static final String NAME = "plocal"; private volatile O2QCache readCache; protected final OClosableLinkedContainer<Long, OFileClassic> files = new OClosableLinkedContainer<Long, OFileClassic>( OGlobalConfiguration.OPEN_FILES_LIMIT.getValueAsInteger()); public OEngineLocalPaginated() { } @Override public void startup() { OMemoryAndLocalPaginatedEnginesInitializer.INSTANCE.initialize(); super.startup(); readCache = new O2QCache(calculateReadCacheMaxMemory(OGlobalConfiguration.DISK_CACHE_SIZE.getValueAsLong() * 1024 * 1024), OGlobalConfiguration.DISK_CACHE_PAGE_SIZE.getValueAsInteger() * 1024, true, OGlobalConfiguration.DISK_CACHE_PINNED_PAGES.getValueAsInteger()); try { if (OByteBufferPool.instance() != null) OByteBufferPool.instance().registerMBean(); } catch (Exception e) { OLogManager.instance().error(this, "MBean for byte buffer pool cannot be registered", e); } } private long calculateReadCacheMaxMemory(final long cacheSize) { return (long) (cacheSize * ((100 - OGlobalConfiguration.DISK_WRITE_CACHE_PART.getValueAsInteger()) / 100.0)); } /** * @param cacheSize Cache size in bytes. * @see O2QCache#changeMaximumAmountOfMemory(long) */ public void changeCacheSize(final long cacheSize) { if (readCache != null) readCache.changeMaximumAmountOfMemory(calculateReadCacheMaxMemory(cacheSize)); //otherwise memory size will be set during cache initialization. } public OStorage createStorage(final String dbName, final Map<String, String> configuration) { try { return new OLocalPaginatedStorage(dbName, dbName, getMode(configuration), generateStorageId(), readCache, files); } catch (Exception e) { final String message = "Error on opening database: " + dbName + ". Current location is: " + new java.io.File(".").getAbsolutePath(); OLogManager.instance().error(this, message, e); throw OException.wrapException(new ODatabaseException(message), e); } } public String getName() { return NAME; } public O2QCache getReadCache() { return readCache; } @Override public String getNameFromPath(String dbPath) { return OIOUtils.getRelativePathIfAny(dbPath, null); } @Override public void shutdown() { try { readCache.clear(); files.clear(); try { if (OByteBufferPool.instance() != null) OByteBufferPool.instance().unregisterMBean(); } catch (Exception e) { OLogManager.instance().error(this, "MBean for byte buffer pool cannot be unregistered", e); } } finally { super.shutdown(); } } }