ES 源代码阅读(一)

启动流程分析:node

入口:org.elasticsearch.bootstrap.Elasticsearch->org.elasticsearch.bootstrap.Bootstrap->bootstrap

生成实例->写进程号->初始化配置文件->初始化设置实例->运行->关闭处理app

在初始化设置实例过程当中
使用初始化的配置文件初始化node实例,并设置关闭处理.在初始化node过程当中,初始化的是InternalNode实例.
在其中的start方法中 使用guice框架,加载不一样模块.
首先加载Discovery.class实例,而后执行设置其路由服务.
根据配置能够生成LocalDiscovery和ZenDiscovery.
而后初始化MappingUpdateAction.启动相关线程.
而后依次加载:IndicesService,和IndexingMemoryController,IndicesClusterStateService,IndicesTTLService
RiversManager,SnapshotsService,
TransportService 启动一系列工做线程.
ClusterService ,RoutingService,SearchService,MonitorService,RestController.框架

LocalGatewayAllocator 初始化elasticsearch

启动DiscoveryService 启动相关线程,初始化GatewayService,启动HTTPServer 启动相关线程,初始化BulkUdpService,初始化ResourceWatcherService,初始化TribeService
以上所有组件设置为启动状态.源码分析

当Es处理请求时,会根据请求建立相关EVENT,而后将其和一系列相关listener结合交给线程池去执行,执行过程总,会遍历每一个listener,其中传递的参数就是Event,而后执行相关操做.ui

接下来会结合实际建立索引时的实例来进行源码分析.线程

相关文章
相关标签/搜索