
com.hazelcast.replicatedmap.impl.ReplicatedMapProxy Maven / Gradle / Ivy
/*
* Copyright (c) 2008-2016, Hazelcast, Inc. All Rights Reserved.
*
* 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.
*/
package com.hazelcast.replicatedmap.impl;
import com.hazelcast.config.ReplicatedMapConfig;
import com.hazelcast.core.EntryListener;
import com.hazelcast.core.ReplicatedMap;
import com.hazelcast.internal.serialization.SerializationService;
import com.hazelcast.monitor.LocalReplicatedMapStats;
import com.hazelcast.nio.Address;
import com.hazelcast.nio.serialization.Data;
import com.hazelcast.partition.impl.InternalPartitionServiceImpl;
import com.hazelcast.query.Predicate;
import com.hazelcast.replicatedmap.impl.client.ReplicatedMapEntries;
import com.hazelcast.replicatedmap.impl.operation.ClearOperationFactory;
import com.hazelcast.replicatedmap.impl.operation.PutAllOperation;
import com.hazelcast.replicatedmap.impl.operation.PutOperation;
import com.hazelcast.replicatedmap.impl.operation.RemoveOperation;
import com.hazelcast.replicatedmap.impl.operation.RequestMapDataOperation;
import com.hazelcast.replicatedmap.impl.operation.VersionResponsePair;
import com.hazelcast.replicatedmap.impl.record.ReplicatedEntryEventFilter;
import com.hazelcast.replicatedmap.impl.record.ReplicatedQueryEventFilter;
import com.hazelcast.replicatedmap.impl.record.ReplicatedRecordStore;
import com.hazelcast.replicatedmap.impl.record.ResultSet;
import com.hazelcast.spi.AbstractDistributedObject;
import com.hazelcast.spi.EventFilter;
import com.hazelcast.spi.InitializingObject;
import com.hazelcast.spi.InternalCompletableFuture;
import com.hazelcast.spi.NodeEngine;
import com.hazelcast.spi.Operation;
import com.hazelcast.spi.OperationService;
import com.hazelcast.spi.impl.eventservice.impl.TrueEventFilter;
import com.hazelcast.util.ExceptionUtil;
import com.hazelcast.util.IterationType;
import java.util.AbstractMap;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import static com.hazelcast.replicatedmap.impl.ReplicatedMapService.SERVICE_NAME;
import static com.hazelcast.util.Preconditions.checkNotNull;
import static com.hazelcast.util.Preconditions.isNotNull;
/**
* Proxy implementation of {@link com.hazelcast.core.ReplicatedMap} interface.
*
* @param key type
* @param value type
*/
public class ReplicatedMapProxy extends AbstractDistributedObject
implements ReplicatedMap, InitializingObject {
private static final int WAIT_INTERVAL_MILLIS = 1000;
private static final int RETRY_INTERVAL_COUNT = 3;
private final String name;
private final NodeEngine nodeEngine;
private final ReplicatedMapService service;
private final SerializationService serializationService;
private final InternalPartitionServiceImpl partitionService;
private final ReplicatedMapConfig config;
private final ReplicatedMapEventPublishingService eventPublishingService;
private int retryCount;
ReplicatedMapProxy(NodeEngine nodeEngine, String name, ReplicatedMapService service) {
super(nodeEngine, service);
this.name = name;
this.nodeEngine = nodeEngine;
this.service = service;
this.eventPublishingService = service.getEventPublishingService();
this.serializationService = nodeEngine.getSerializationService();
this.partitionService = (InternalPartitionServiceImpl) nodeEngine.getPartitionService();
this.config = service.getReplicatedMapConfig(name);
}
@Override
public void initialize() {
service.initializeListeners(name);
if (nodeEngine.getClusterService().getSize() == 1) {
return;
}
fireMapDataLoadingTasks();
if (!config.isAsyncFillup()) {
for (int i = 0; i < nodeEngine.getPartitionService().getPartitionCount(); i++) {
ReplicatedRecordStore store = service.getReplicatedRecordStore(name, false, i);
while (!store.isLoaded()) {
if ((retryCount++) % RETRY_INTERVAL_COUNT == 0) {
requestDataForPartition(i);
}
sleep();
}
}
}
}
private void sleep() {
try {
TimeUnit.MILLISECONDS.sleep(WAIT_INTERVAL_MILLIS);
} catch (InterruptedException e) {
ExceptionUtil.rethrow(e);
}
}
private void fireMapDataLoadingTasks() {
for (int i = 0; i < nodeEngine.getPartitionService().getPartitionCount(); i++) {
Address thisAddress = nodeEngine.getThisAddress();
Address ownerAddress = partitionService.getPartitionOwner(i);
if (thisAddress.equals(ownerAddress)) {
continue;
}
requestDataForPartition(i);
}
}
private void requestDataForPartition(int partitionId) {
RequestMapDataOperation requestMapDataOperation = new RequestMapDataOperation(name);
OperationService operationService = nodeEngine.getOperationService();
operationService
.createInvocationBuilder(SERVICE_NAME, requestMapDataOperation, partitionId)
.setTryCount(ReplicatedMapService.INVOCATION_TRY_COUNT)
.invoke();
}
@Override
public String getName() {
return name;
}
@Override
public String getPartitionKey() {
return getName();
}
@Override
public String getServiceName() {
return SERVICE_NAME;
}
@Override
public int size() {
Collection stores = service.getAllReplicatedRecordStores(getName());
int size = 0;
for (ReplicatedRecordStore store : stores) {
size += store.size();
}
return size;
}
@Override
public boolean isEmpty() {
Collection stores = service.getAllReplicatedRecordStores(getName());
for (ReplicatedRecordStore store : stores) {
if (!store.isEmpty()) {
return false;
}
}
return true;
}
@Override
public boolean containsKey(Object key) {
isNotNull(key, "key");
int partitionId = partitionService.getPartitionId(key);
ReplicatedRecordStore store = service.getReplicatedRecordStore(name, false, partitionId);
return store.containsKey(key);
}
@Override
public boolean containsValue(Object value) {
isNotNull(value, "value");
Collection stores = service.getAllReplicatedRecordStores(getName());
for (ReplicatedRecordStore store : stores) {
if (store.containsValue(value)) {
return true;
}
}
return false;
}
@Override
public V get(Object key) {
isNotNull(key, "key");
int partitionId = partitionService.getPartitionId(key);
ReplicatedRecordStore store = service.getReplicatedRecordStore(getName(), false, partitionId);
return (V) store.get(key);
}
@Override
public V put(K key, V value) {
isNotNull(key, "key must not be null!");
isNotNull(value, "value must not be null!");
Data dataKey = nodeEngine.toData(key);
Data dataValue = nodeEngine.toData(value);
int partitionId = nodeEngine.getPartitionService().getPartitionId(dataKey);
PutOperation putOperation = new PutOperation(getName(), dataKey, dataValue);
InternalCompletableFuture
© 2015 - 2025 Weber Informatics LLC | Privacy Policy