这篇文章主要介绍“elasticsearch集群cluster主要功能是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“elasticsearch集群cluster主要功能是什么”文章能帮助大家解决问题。
elasticsearch的集群功能代码在cluster包中,通过ClusterService接口对外暴露。
cluster主要包括以下功能:
发现(Discovery),路由(routing),传送功能(transport),集群状态(clusterstates)等。
发现功能功能主要用于节点启动后发现集群,master向所有节点发布集群状态,选举master节点并引发集群节点变得事件;
routing记录了集群中各个shard的位置,为节点提供数据信息;
transport是节点间交流的主要通道,elasticsearch应用了netty框架实现了功能强大的transport功能;
集群状态(clusterstates)实现了一些集群状态,同时提供了一些方法,在集群每次变得时,master节点都会重新构建clusterstates,并将集群状态发送给每个节点。
节点根据cluster状态来确定某些操作是否能执行。
下图是显示了clusterstate的主要Fields
clusterstate的version是clusterstate的版本每次被更新它都会增加,routingTables包含了集群中所有索引的位置信息,nodes是当前集群中的所有节点,metaData是索引的一些元数据,blocks包含了集群的阻塞状态,
集群一共有三种阻塞级别:read,write和matedata;
status集群的状态有四种:unknown,RECEIVED,BEING_APPLIED,APPLIED。
集群功能的接口clusterservice的继承关系如下所示:
所有实现都在InternalClusterService中,它同时继承了AutoCloseAble接口和LifecycleComponent接口。
上图为clusterservice的方法,这些方法包括集群的启动与关闭,集群状态修改和发布及节点间ping通信等,这些方法只是从从内部看集群是不存在实体的,它的功能是由一个个节点实现的。因此对于集群的操作最终还是对每个节点的操作。单有些操作只能由master来进行,有些则是所有节点都需要进行的操作。每个加入集群后就会增加clusterstatelistener及localmasterlisener,但是clusterstate的发布则只能由master节点来实现。
关于“elasticsearch集群cluster主要功能是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。