org.infinispan.persistence.remote.upgrade.HotRodMigratorHelper Maven / Gradle / Ivy
package org.infinispan.persistence.remote.upgrade;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
import org.infinispan.Cache;
import org.infinispan.client.hotrod.MetadataValue;
import org.infinispan.client.hotrod.RemoteCache;
import org.infinispan.client.hotrod.impl.protocol.VersionUtils;
import org.infinispan.commons.CacheException;
import org.infinispan.commons.util.CloseableIterator;
import org.infinispan.container.versioning.NumericVersion;
import org.infinispan.context.Flag;
import org.infinispan.metadata.EmbeddedMetadata;
import org.infinispan.metadata.Metadata;
import org.infinispan.metadata.impl.InternalMetadataImpl;
import org.infinispan.persistence.remote.logging.Log;
import org.infinispan.util.logging.LogFactory;
/**
* @author gustavonalle
* @since 8.2
*/
public class HotRodMigratorHelper {
static final String MIGRATION_MANAGER_HOT_ROD_KNOWN_KEYS = "___MigrationManager_HotRod_KnownKeys___";
static final String ITERATOR_MINIMUM_VERSION = "2.5";
static final int DEFAULT_READ_BATCH_SIZE = 10000;
private static final Log log = LogFactory.getLog(HotRodMigratorHelper.class, Log.class);
static boolean supportsIteration(String protocolVersion) {
return protocolVersion == null || VersionUtils.isVersionGreaterOrEquals(protocolVersion, ITERATOR_MINIMUM_VERSION);
}
static List range(int end) {
List integers = new ArrayList<>();
for (int i = 0; i < end; i++) {
integers.add(i);
}
return integers;
}
static List> split(List list, final int parts) {
List> subLists = new ArrayList<>(parts);
for (int i = 0; i < parts; i++) {
subLists.add(new ArrayList());
}
for (int i = 0; i < list.size(); i++) {
subLists.get(i % parts).add(list.get(i));
}
return subLists;
}
static void gracefulShutdown(ExecutorService executorService) {
try {
executorService.shutdown();
while (!executorService.awaitTermination(500, TimeUnit.MILLISECONDS)) {
}
} catch (InterruptedException e) {
throw new CacheException(e);
}
}
static void migrateEntriesWithMetadata(RemoteCache
© 2015 - 2025 Weber Informatics LLC | Privacy Policy