zoukankan      html  css  js  c++  java
  • elasticSearch6源码分析(5)gateway模块

    1.gateway概述

    The local gateway module stores the cluster state and shard data across full cluster restarts.

    2.gatewaymodule模块

        @Override
        protected void configure() {
            bind(DanglingIndicesState.class).asEagerSingleton();
            bind(GatewayService.class).asEagerSingleton();
            bind(TransportNodesListGatewayMetaState.class).asEagerSingleton();
            bind(TransportNodesListGatewayStartedShards.class).asEagerSingleton();
            bind(LocalAllocateDangledIndices.class).asEagerSingleton();
        }

    2.1 DanglingIndicesState

    /**
     * The dangling indices state is responsible for finding new dangling indices (indices that have
     * their state written on disk, but don't exists in the metadata of the cluster), and importing
     * them into the cluster.
     */

    2.2 GatewayService 

     配置信息

        public static final Setting<Integer> EXPECTED_NODES_SETTING =
            Setting.intSetting("gateway.expected_nodes", -1, -1, Property.NodeScope);
        public static final Setting<Integer> EXPECTED_DATA_NODES_SETTING =
            Setting.intSetting("gateway.expected_data_nodes", -1, -1, Property.NodeScope);
        public static final Setting<Integer> EXPECTED_MASTER_NODES_SETTING =
            Setting.intSetting("gateway.expected_master_nodes", -1, -1, Property.NodeScope);
        public static final Setting<TimeValue> RECOVER_AFTER_TIME_SETTING =
            Setting.positiveTimeSetting("gateway.recover_after_time", TimeValue.timeValueMillis(0), Property.NodeScope);
        public static final Setting<Integer> RECOVER_AFTER_NODES_SETTING =
            Setting.intSetting("gateway.recover_after_nodes", -1, -1, Property.NodeScope);
        public static final Setting<Integer> RECOVER_AFTER_DATA_NODES_SETTING =
            Setting.intSetting("gateway.recover_after_data_nodes", -1, -1, Property.NodeScope);
        public static final Setting<Integer> RECOVER_AFTER_MASTER_NODES_SETTING =
            Setting.intSetting("gateway.recover_after_master_nodes", 0, 0, Property.NodeScope);

    2.3 TransportNodesListGatewayStartedShards

    /**
     * This transport action is used to fetch the shard version from each node during primary allocation in {@link GatewayAllocator}.
     * We use this to find out which node holds the latest shard version and which of them used to be a primary in order to allocate
     * shards after node or cluster restarts.
     */
  • 相关阅读:
    KeBugCheckEx0xD1
    Ti DSP编程入门
    动态链接库
    Hello,world! x86版本
    用回调函数联系两个模块
    DataGrid模版列超级链接列传递参数问题总结(多个参数传递)
    后台代码里执行弹出脚本方法!(Response.Write)
    Oracle数据导入导出imp/exp
    安装sql2000: 出现 A previous program installation created pending file operations on the installation machine. You must restart the computer before running setup
    解决问题:  An unhandled exception of type 'System.Exception' occurred in system.data.oracleclient.dll
  • 原文地址:https://www.cnblogs.com/davidwang456/p/10109692.html
Copyright © 2011-2022 走看看