极客时间学习笔记
简介
elasticsearch是用java语言开发的基于lucene的全文搜索引擎。
特性
高可用,可扩展的分布式系统
服务可以用性-允许有节点停止服务
数据可用性-部分节点丢失不会丢失数据
扩展性-请求量提升/数据不断增长(将数据分不到多有节点上),水平扩容
分布式架构
不同的集群通过不同的名字区分,默认名字 “elasticsearch”,可以通过配置文件或者命令行启动时中 -E cluster.name = xxx 设定 配置文件
一个集群可以有一个或多个节点
节点
节点是一个elasticsearch的实例,本质上是一个java的进程,一台机器可以运行多个节点,生产环境建议一台机器只运行一个elasticsearch实例
每个节点都有自己的名字,通过配置文件,或者启东时 -e node.name = xxx 指定,节点启动后会分配一个UID,保存在data目录下
Master-eligible nodes 和 Master Node
每个节点启动后,默认就是一个master eligible 节点(可以通过配置关闭 node.master:false)
每一个Master-eligible节点都可以参加选主流程,成为Master节点
第一个Master-eligible节点启动时会将自己选举为Master节点
每个节点上都保存了集群的状态,只有Master节点才能修改集群的状态(大哥说了算,保持数据一致性)
集群状态中存储了必要信息 :所有节点的信息;所有索引和相关Mapping与Setting信息;分片路由信息
Data node 和 Coordinaing Node
Data node 保存数据的节点,负责保存分片数据,数据扩展时起重要作用(待补充)
Coordinating Node
负责接受Client请求,将请求分发到合适的节点,最终把结果汇总到一起,每个节点默认都起到Coordinating Node的职责
其他的节点类型
Hot & Warm Node 不同配置的Data Node,用来实现Hot & Warm 架构 降低集群部署成本,Hot高配置机器,Warm低配置机器。
Machine Learning Node 负责跑机器学习 Job ,用来做异常检测
Tribe Node 连接不同的Es集群并支持将这些集群当成一个单独集群处理后续版本将会废弃,5.3开始使用Search across clusters替代
配置节点类型
开发环境一个节点可以承担多种角色
生产环境设置单一的角色节点(dedicated node)
节点类型 | 配置参数 | 默认值 |
maste eligible | node.master | true |
data | node.data | true |
ingest | node.ingest | true |
coordinating only | 无 | 每个节点默认都是coordinating节点设置其他类型全部为false |
machine learning | node.ml | true(需 enable x-pack) |
分片(Primary shard & Replica Shard)
主分片,用以解决数据水平扩展的问题,通过主分片,可以将数据分布到集群内的所有节点之上
- 一个分片是一个运行的Lucene的实例
- 主分片数在索引创建时指定,后续不允许修改,除非Reindex
副本分片,用以解决数据高可用的问题。分片是主分片的拷贝
- 副本分片数,可以动态的调整
- 增加副本数,一定程度上提高服务的可用性(读取的吞吐量)
分片的设定
对于生产环境中分片的设定,需要提前做好容量规划
分片数设置过小
- 导致后续无法增加节点实现水平扩展
- 单个分片的数据量太大,导致数据重新分配耗时
分片数设置过大,7.0开始,默认主分片设置成1,解决了over-sharding的问题
- 影响搜索结果的相关性打分,影响统计结果的准确性
- 单个节点上过多的分片会导致资源浪费同事也会影响性能
查看集群状态
GET _cluster/health
{
"cluster_name" : "elasticsearch",
"status" : "yellow",//green主分片与副分片都正常 yellow主分片全部分配正常,有副本分片未能正常分配,red有主分片未能分配,例如当服务器磁盘容量超过85%去创建新的索引时
"timed_out" : false,
"number_of_nodes" : 1,
"number_of_data_nodes" : 1,
"active_primary_shards" : 7,
"active_shards" : 7,
"relocating_shards" : 0,
"initializing_shards" : 0,
"unassigned_shards" : 1,
"delayed_unassigned_shards" : 0,
"number_of_pending_tasks" : 0,
"number_of_in_flight_fetch" : 0,
"task_max_waiting_in_queue_millis" : 0,
"active_shards_percent_as_number" : 87.5
}