当前位置: 首页>>代码示例>>Java>>正文


Java ClusterChangedEvent.state方法代码示例

本文整理汇总了Java中org.elasticsearch.cluster.ClusterChangedEvent.state方法的典型用法代码示例。如果您正苦于以下问题:Java ClusterChangedEvent.state方法的具体用法?Java ClusterChangedEvent.state怎么用?Java ClusterChangedEvent.state使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.elasticsearch.cluster.ClusterChangedEvent的用法示例。


在下文中一共展示了ClusterChangedEvent.state方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: applyClusterState

import org.elasticsearch.cluster.ClusterChangedEvent; //导入方法依赖的package包/类
@Override
public synchronized void applyClusterState(final ClusterChangedEvent event) {
    if (!lifecycle.started()) {
        return;
    }

    final ClusterState state = event.state();

    // we need to clean the shards and indices we have on this node, since we
    // are going to recover them again once state persistence is disabled (no master / not recovered)
    // TODO: feels hacky, a block disables state persistence, and then we clean the allocated shards, maybe another flag in blocks?
    if (state.blocks().disableStatePersistence()) {
        for (AllocatedIndex<? extends Shard> indexService : indicesService) {
            indicesService.removeIndex(indexService.index(), NO_LONGER_ASSIGNED,
                "cleaning index (disabled block persistence)"); // also cleans shards
        }
        return;
    }

    updateFailedShardsCache(state);

    deleteIndices(event); // also deletes shards of deleted indices

    removeUnallocatedIndices(event); // also removes shards of removed indices

    failMissingShards(state);

    removeShards(state);   // removes any local shards that doesn't match what the master expects

    updateIndices(event); // can also fail shards, but these are then guaranteed to be in failedShardsCache

    createIndices(state);

    createOrUpdateShards(state);
}
 
开发者ID:justor,项目名称:elasticsearch_my,代码行数:36,代码来源:IndicesClusterStateService.java

示例2: innerPublish

import org.elasticsearch.cluster.ClusterChangedEvent; //导入方法依赖的package包/类
private void innerPublish(final ClusterChangedEvent clusterChangedEvent, final Set<DiscoveryNode> nodesToPublishTo,
                          final SendingController sendingController, final boolean sendFullVersion,
                          final Map<Version, BytesReference> serializedStates, final Map<Version, BytesReference> serializedDiffs) {

    final ClusterState clusterState = clusterChangedEvent.state();
    final ClusterState previousState = clusterChangedEvent.previousState();
    final TimeValue publishTimeout = discoverySettings.getPublishTimeout();

    final long publishingStartInNanos = System.nanoTime();

    for (final DiscoveryNode node : nodesToPublishTo) {
        // try and serialize the cluster state once (or per version), so we don't serialize it
        // per node when we send it over the wire, compress it while we are at it...
        // we don't send full version if node didn't exist in the previous version of cluster state
        if (sendFullVersion || !previousState.nodes().nodeExists(node)) {
            sendFullClusterState(clusterState, serializedStates, node, publishTimeout, sendingController);
        } else {
            sendClusterStateDiff(clusterState, serializedDiffs, serializedStates, node, publishTimeout, sendingController);
        }
    }

    sendingController.waitForCommit(discoverySettings.getCommitTimeout());

    try {
        long timeLeftInNanos = Math.max(0, publishTimeout.nanos() - (System.nanoTime() - publishingStartInNanos));
        final BlockingClusterStatePublishResponseHandler publishResponseHandler = sendingController.getPublishResponseHandler();
        sendingController.setPublishingTimedOut(!publishResponseHandler.awaitAllNodes(TimeValue.timeValueNanos(timeLeftInNanos)));
        if (sendingController.getPublishingTimedOut()) {
            DiscoveryNode[] pendingNodes = publishResponseHandler.pendingNodes();
            // everyone may have just responded
            if (pendingNodes.length > 0) {
                logger.warn("timed out waiting for all nodes to process published state [{}] (timeout [{}], pending nodes: {})",
                    clusterState.version(), publishTimeout, pendingNodes);
            }
        }
    } catch (InterruptedException e) {
        // ignore & restore interrupt
        Thread.currentThread().interrupt();
    }
}
 
开发者ID:justor,项目名称:elasticsearch_my,代码行数:41,代码来源:PublishClusterStateAction.java

示例3: testNoWriteIfNothingChanged

import org.elasticsearch.cluster.ClusterChangedEvent; //导入方法依赖的package包/类
public void testNoWriteIfNothingChanged() throws Exception {
    boolean initializing = false;
    boolean versionChanged = false;
    boolean stateInMemory = true;
    boolean masterEligible = randomBoolean();
    boolean expectMetaData = false;
    ClusterChangedEvent event = generateEvent(initializing, versionChanged, masterEligible);
    ClusterChangedEvent newEventWithNothingChanged = new ClusterChangedEvent("test cluster state", event.state(), event.state());
    assertState(newEventWithNothingChanged, stateInMemory, expectMetaData);
}
 
开发者ID:justor,项目名称:elasticsearch_my,代码行数:11,代码来源:GatewayMetaStateTests.java

示例4: clusterChanged

import org.elasticsearch.cluster.ClusterChangedEvent; //导入方法依赖的package包/类
@Override
public void clusterChanged(ClusterChangedEvent event) {
    clusterState = event.state();
}
 
开发者ID:justor,项目名称:elasticsearch_my,代码行数:5,代码来源:ScriptService.java

示例5: publish

import org.elasticsearch.cluster.ClusterChangedEvent; //导入方法依赖的package包/类
private void publish(final ClusterChangedEvent clusterChangedEvent, final Set<DiscoveryNode> nodesToPublishTo,
                     final BlockingClusterStatePublishResponseHandler publishResponseHandler) {

    Map<Version, BytesReference> serializedStates = Maps.newHashMap();
    Map<Version, BytesReference> serializedDiffs = Maps.newHashMap();

    final ClusterState clusterState = clusterChangedEvent.state();
    final ClusterState previousState = clusterChangedEvent.previousState();
    final AtomicBoolean timedOutWaitingForNodes = new AtomicBoolean(false);
    final TimeValue publishTimeout = discoverySettings.getPublishTimeout();
    final boolean sendFullVersion = !discoverySettings.getPublishDiff() || previousState == null;
    Diff<ClusterState> diff = null;

    for (final DiscoveryNode node : nodesToPublishTo) {

        // try and serialize the cluster state once (or per version), so we don't serialize it
        // per node when we send it over the wire, compress it while we are at it...
        // we don't send full version if node didn't exist in the previous version of cluster state
        if (sendFullVersion || !previousState.nodes().nodeExists(node.id())) {
            sendFullClusterState(clusterState, serializedStates, node, timedOutWaitingForNodes, publishTimeout, publishResponseHandler);
        } else {
            if (diff == null) {
                diff = clusterState.diff(previousState);
            }
            sendClusterStateDiff(clusterState, diff, serializedDiffs, node, timedOutWaitingForNodes, publishTimeout, publishResponseHandler);
        }
    }

    if (publishTimeout.millis() > 0) {
        // only wait if the publish timeout is configured...
        try {
            timedOutWaitingForNodes.set(!publishResponseHandler.awaitAllNodes(publishTimeout));
            if (timedOutWaitingForNodes.get()) {
                DiscoveryNode[] pendingNodes = publishResponseHandler.pendingNodes();
                // everyone may have just responded
                if (pendingNodes.length > 0) {
                    logger.warn("timed out waiting for all nodes to process published state [{}] (timeout [{}], pending nodes: {})", clusterState.version(), publishTimeout, pendingNodes);
                }
            }
        } catch (InterruptedException e) {
            // ignore & restore interrupt
            Thread.currentThread().interrupt();
        }
    }
}
 
开发者ID:baidu,项目名称:Elasticsearch,代码行数:46,代码来源:PublishClusterStateAction.java


注:本文中的org.elasticsearch.cluster.ClusterChangedEvent.state方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。