All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.counter.impl.manager.PersistedCounterConfigurationStorage Maven / Gradle / Ivy

There is a newer version: 15.1.0.Dev05
Show newest version
package org.infinispan.counter.impl.manager;

import static org.infinispan.commons.util.Util.renameTempFile;
import static org.infinispan.counter.configuration.ConvertUtil.parsedConfigToConfig;
import static org.infinispan.counter.logging.Log.CONTAINER;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.stream.Collectors;

import javax.xml.stream.XMLStreamException;

import org.infinispan.configuration.global.GlobalStateConfiguration;
import org.infinispan.counter.api.CounterConfiguration;
import org.infinispan.counter.api.Storage;
import org.infinispan.counter.configuration.AbstractCounterConfiguration;
import org.infinispan.counter.configuration.ConvertUtil;
import org.infinispan.counter.configuration.CounterConfigurationParser;
import org.infinispan.counter.configuration.CounterConfigurationSerializer;
import org.infinispan.counter.logging.Log;
import org.infinispan.manager.EmbeddedCacheManager;
import org.infinispan.util.logging.LogFactory;

/**
 * A persistent implementation of {@link CounterConfigurationStorage}.
 * 

* The counter's configuration will be stored (as xml format) in {@code counters.xml} file in {@link GlobalStateConfiguration#sharedPersistentLocation()} * * @author Pedro Ruivo * @since 9.2 */ public class PersistedCounterConfigurationStorage implements CounterConfigurationStorage { private static final Log log = LogFactory.getLog(PersistedCounterConfigurationStorage.class, Log.class); private final Map storage; private final CounterConfigurationSerializer serializer; private final CounterConfigurationParser parser; private volatile String sharedDirectory; PersistedCounterConfigurationStorage() { storage = new ConcurrentHashMap<>(); serializer = new CounterConfigurationSerializer(); parser = new CounterConfigurationParser(); } private static AbstractCounterConfiguration fromEntry(Map.Entry entry) { return ConvertUtil.configToParsedConfig(entry.getKey(), entry.getValue()); } @Override public Map loadAll() { try { doLoadAll(); } catch (IOException | XMLStreamException e) { throw CONTAINER.errorReadingCountersConfiguration(e); } return storage; } @Override public void store(String name, CounterConfiguration configuration) { if (configuration.storage() == Storage.VOLATILE) { //don't store volatile counters! return; } storage.put(name, configuration); try { doStoreAll(); } catch (IOException | XMLStreamException e) { throw CONTAINER.errorPersistingCountersConfiguration(e); } } @Override public void remove(String name) { storage.remove(name); } @Override public void validatePersistence(CounterConfiguration configuration) { //nothing to validate } @Override public void initialize(EmbeddedCacheManager cacheManager) { sharedDirectory = cacheManager.getCacheManagerConfiguration().globalState().sharedPersistentLocation(); } private void doStoreAll() throws IOException, XMLStreamException { File directory = getSharedDirectory(); File temp = File.createTempFile("counters", null, directory); try (FileOutputStream f = new FileOutputStream(temp)) { serializer.serializeConfigurations(f, convertToList()); } File persistentFile = getPersistentFile(); try { renameTempFile(temp, getFileLock(), persistentFile); } catch (Exception e) { throw CONTAINER.cannotRenamePersistentFile(temp.getAbsolutePath(), persistentFile, e); } } private void doLoadAll() throws XMLStreamException, IOException { File file = getPersistentFile(); try (FileInputStream fis = new FileInputStream(file)) { convertToMap(parser.parseConfigurations(fis)); } catch (FileNotFoundException e) { if (log.isTraceEnabled()) { log.tracef("File '%s' does not exist. Skip loading.", file.getAbsolutePath()); } } } private List convertToList() { return storage.entrySet().stream() .map(PersistedCounterConfigurationStorage::fromEntry) .collect(Collectors.toList()); } private void convertToMap(List configs) { configs.forEach(c -> storage.put(c.name(), parsedConfigToConfig(c))); } private File getSharedDirectory() { File directory = new File(sharedDirectory); if (!directory.exists()) { boolean created = directory.mkdirs(); if (log.isTraceEnabled()) { log.tracef("Shared directory created? %s", created); } } return directory; } private File getPersistentFile() { return new File(sharedDirectory, "counters.xml"); } private File getFileLock() { return new File(sharedDirectory, "counters.xml.lck"); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy