5个 Elasticsearch 核心组件

本文涉及的产品
Elasticsearch Serverless通用抵扣包,测试体验金 200元
简介: Elasticsearch 是基于 Lucene 的分布式搜索引擎,具备高可用和多租户特性。其核心组件包括:节点(Node)、集群(Cluster)、索引(Index)、分片(Shard)和副本(Replica)。节点是集群中的服务器,可设置为主、数据或客户端节点。集群由多个节点组成,通过集群名称区分。索引是文档集合,7.x 版本后每个索引仅含一种类型。分片是索引的子集,可分布于不同节点,分为主分片和副本分片,副本用于提高数据可用性和性能。【5月更文挑战第5天】

Elasticsearch 是一个基于 Lucene 的搜索引擎,它提供了分布式、高可用、多租户的能力。Elasticsearch 的核心组件包括节点(Node)、集群(Cluster)、索引(Index)、分片(Shard)、副本(Replica)等。下面我将结合案例代码解释和说明这些核心组件。

节点(Node)

节点是 Elasticsearch 集群中的一个服务器,它负责存储数据和处理客户端请求。节点可以通过配置文件或启动参数设置角色,如主节点(Master)、数据节点(Data)、客户端节点(Client)等。

案例代码:

// 创建一个节点设置
Settings settings = Settings.builder()
        .put("node.name", "node-1")
        .put("cluster.name", "my-cluster")
        .put("path.data", "/path/to/data")
        .put("path.logs", "/path/to/logs")
        .build();
// 创建一个节点
Node node = new Node(settings);

集群(Cluster)

集群是由一个或多个节点组成的,它们共同协作提供数据的存储和搜索服务。集群通过集群名称来区分,确保不同集群之间不会发生数据共享。

案例代码:

// 创建一个集群客户端
TransportClient client = new PreBuiltTransportClient(Settings.EMPTY)
        .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("host1"), 9300))
        .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("host2"), 9300));
// 关闭客户端
client.close();

索引(Index)

索引是具有相似特征的文档集合。索引可以包含一个或多个类型(Type),每种类型都有自己的字段映射。在 Elasticsearch 7.x 版本中,一个索引只能包含一个类型。

案例代码:

// 创建一个索引
CreateIndexRequest request = new CreateIndexRequest("my-index");
client.admin().indices().create(request).actionGet();

分片(Shard)

分片是索引数据的子集,它可以将一个大的索引拆分成多个部分,分布在不同的节点上。分片可以是主分片(Primary Shard)或副本分片(Replica Shard)。

案例代码:

// 创建一个索引,设置分片数量和副本数量
request = new CreateIndexRequest("my-index")
        .settings(Settings.builder()
                .put("number_of_shards", 3)
                .put("number_of_replicas", 2));
client.admin().indices().create(request).actionGet();

副本(Replica)

副本是分片的复制,可以提高数据的可用性和搜索性能。副本可以分布在不同的节点上,当主分片发生故障时,副本可以升级为主分片。

案例代码:

// 更新索引副本数量
UpdateIndexRequest updateRequest = new UpdateIndexRequest("my-index")
        .settings(Settings.builder()
                .put("number_of_replicas", 1));
client.admin().indices().updateSettings(updateRequest).actionGet();

以上是 Elasticsearch 核心组件的简要介绍和案例代码解释。要深入了解这些组件的原理和实现,建议阅读 Elasticsearch 官方文档和源码。

相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。  
相关文章
|
JavaScript 大数据 Python
原生大数据|elasticSearch|低版本kibana组件的汉化
原生大数据|elasticSearch|低版本kibana组件的汉化
230 0
|
JSON 流计算 数据格式
【天衍系列 04】深入理解Flink的ElasticsearchSink组件:实时数据流如何无缝地流向Elasticsearch
【天衍系列 04】深入理解Flink的ElasticsearchSink组件:实时数据流如何无缝地流向Elasticsearch
821 2
|
数据安全/隐私保护
Elasticsearch 7.12 启用 x-pack 组件
Elasticsearch 7.12 启用 x-pack 组件
405 0
|
安全 Java Apache
elasticsearch 升级Apache Log4j2组件包
elasticsearch 升级Apache Log4j2组件包
1465 0
|
人工智能 安全 物联网
12月11日云栖精选夜读:【X-Pack解读】阿里云Elasticsearch X-Pack Graph组件功能详解
阿里云Elasticsearch集成了Elastic Stack商业版的X-Pack组件包,包括安全、告警、监控、报表生成、图分析、机器学习等组件,用户可以开箱即用。本文将对X-Pack 的Graph组件功能进行详细解读。
2744 0
|
机器学习/深度学习
【X-Pack解读】阿里云Elasticsearch X-Pack 机器学习组件功能详解
阿里云Elasticsearch集成了Elastic Stack商业版的X-Pack组件包,包括安全、告警、监控、报表生成、图分析、机器学习等组件,用户可以开箱即用。本文将对X-Pack 的机器学习功能进行详细解读。
7043 0
|
安全 API 索引
【X-Pack解读】阿里云Elasticsearch X-Pack Graph组件功能详解
阿里云Elasticsearch集成了Elastic Stack商业版的X-Pack组件包,包括安全、告警、监控、报表生成、图分析、机器学习等组件,用户可以开箱即用。本文将对X-Pack 的Graph组件功能进行详细解读。
7070 0
|
数据可视化 大数据
【X-Pack解读】阿里云Elasticsearch X-Pack 报告组件功能详解
阿里云Elasticsearch集成了Elastic Stack商业版的X-Pack组件包,包括安全、告警、监控、报表生成、图分析、机器学习等组件,用户可以开箱即用。本文将对X-Pack 的报告组件功能进行详细解读。
4287 0
|
监控 大数据 索引
【X-Pack解读】阿里云Elasticsearch X-Pack 监控组件功能详解
阿里云Elasticsearch集成了Elastic Stack商业版的X-Pack组件包,包括安全、告警、监控、报表生成、图分析、机器学习等组件,用户可以开箱即用。本文将对X-Pack 的监控组件功能进行详细解读。
10003 0
|
机器学习/深度学习 监控 安全
【X-Pack解读】阿里云Elasticsearch X-Pack 告警组件功能详解
阿里云Elasticsearch集成了Elastic Stack商业版的X-Pack组件包,包括安全、告警、监控、报表生成、图分析、机器学习等组件,用户可以开箱即用。本文将对X-Pack 的告警组件功能进行详细解读。
7140 0

热门文章

最新文章

下一篇
开通oss服务