ElasticSearch源代码解析之Client端

简介: 看看EalsticSearch的Client端,作为入口,它代表了Client和Server交互的方式。

如前面在架构思路中的反向思考一样,先通过Client端来看ElasticSearch的设计。
再啰嗦一句:我认为从Client或者说从API用户角度出发来看一个系统最合适的入手点,API的设计是一个非常困难的东西,要平衡易用性,一致性(非数据意义上的一致性),完整性。

简单的代码结构理一下,直接在_client_rest-high-level项目里找到org.elasticsearch.client.RestHighLevelClient这个类,它也是ElasticSearch以后主推的Client,其它的Client,如org.elasticsearch.client.transport.TransportClient会在后续版本7中不建议使用,并在版本8中移除。

org.elasticsearch.client.IndicesClient基于RestHighLevelClient提供了更简单的功能封装,主要包括delete,createIndex等操作,细分析这些方法,发现关键在于Request这个参数,用来清楚地定义Client期望Server所完成的工作,其中有意思的是一些Request继承自org.elasticsearch.action.support.master.MasterNodeRequest,这也说明请求至少可以分为两大类,一类是明确需要MasterNode来完成的,比如delete和create这种操作,还有一类应该是不需要MasterNode来完成的。

这也验证了我前面的分析,就是由MasterNode来负责主要完成数据一致性问题的管理,而由DataNode进行查询等请求。
Request/Response应该是ElasticSearch中不算复杂,但内容特别庞杂的东西,它需要覆盖基本上所有的业务以及管理功能。
顺便吐槽一下,ElasticSearch中的Action,Request,Response太多了,而且很多名字类似,看得极其郁闷。

从client端的定义来看,基本就是通过一个Action来定义行为,Request和Response分别作为Client对Server的输入和输出。这种其实是非常典型的Command设计,即Server端核心轻量化,通过插件化的方式支持扩展,Command对应的扩展会注册很多Handler,然后每个Handler会负责处理相应的Command。非常简单有效的设计,唯一值得吐槽的就是ElasticSearch把Server项目搞得太大,找起来太复杂。

下面带着这个思路再去看Server端代码。

相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。  
相关文章
|
9月前
|
存储 JSON 数据格式
ElasticSearch基础概念解析
以上就是ElasticSearch的基础概念。理解了这些概念,你就可以更好地使用ElasticSearch,像使用超级放大镜一样,在数据海洋中找到你需要的珍珠。
287 71
|
测试技术 开发者 Python
使用Python解析和分析源代码
本文介绍了如何使用Python的`ast`模块解析和分析Python源代码,包括安装准备、解析源代码、分析抽象语法树(AST)等步骤,展示了通过自定义`NodeVisitor`类遍历AST并提取信息的方法,为代码质量提升和自动化工具开发提供基础。
1054 9
|
存储 缓存 监控
深入解析:Elasticsearch集群性能调优策略与最佳实践
【10月更文挑战第8天】Elasticsearch 是一个分布式的、基于 RESTful 风格的搜索和数据分析引擎,它能够快速地存储、搜索和分析大量数据。随着企业对实时数据处理需求的增长,Elasticsearch 被广泛应用于日志分析、全文搜索、安全信息和事件管理(SIEM)等领域。然而,为了确保 Elasticsearch 集群能够高效运行并满足业务需求,需要进行一系列的性能调优工作。
795 3
|
存储 安全 网络协议
Elasticsearch 配置文件解析
【10月更文挑战第3天】Elasticsearch 配置文件解析
407 3
|
JSON 关系型数据库 API
ElasticSearch 的概念解析与使用方式(二)
ElasticSearch 的概念解析与使用方式(二)
214 1
|
存储 搜索推荐 Java
ElasticSearch 的概念解析与使用方式(一)
ElasticSearch 的概念解析与使用方式(一)
403 1
|
消息中间件 监控 关系型数据库
MySQL数据实时同步到Elasticsearch:技术深度解析与实践分享
在当今的数据驱动时代,实时数据同步成为许多应用系统的核心需求之一。MySQL作为关系型数据库的代表,以其强大的事务处理能力和数据完整性保障,广泛应用于各种业务场景中。然而,随着数据量的增长和查询复杂度的提升,单一依赖MySQL进行高效的数据检索和分析变得日益困难。这时,Elasticsearch(简称ES)以其卓越的搜索性能、灵活的数据模式以及强大的可扩展性,成为处理复杂查询需求的理想选择。本文将深入探讨MySQL数据实时同步到Elasticsearch的技术实现与最佳实践。
655 0
|
8月前
|
安全 Java Linux
Linux安装Elasticsearch详细教程
Linux安装Elasticsearch详细教程
1482 64
|
7月前
|
JSON 安全 数据可视化
Elasticsearch(es)在Windows系统上的安装与部署(含Kibana)
Kibana 是 Elastic Stack(原 ELK Stack)中的核心数据可视化工具,主要与 Elasticsearch 配合使用,提供强大的数据探索、分析和展示功能。elasticsearch安装在windows上一般是zip文件,解压到对应目录。文件,elasticsearch8.x以上版本是自动开启安全认证的。kibana安装在windows上一般是zip文件,解压到对应目录。elasticsearch的默认端口是9200,访问。默认用户是elastic,密码需要重置。
3724 0
|
存储 安全 数据管理
如何在 Rocky Linux 8 上安装和配置 Elasticsearch
本文详细介绍了在 Rocky Linux 8 上安装和配置 Elasticsearch 的步骤,包括添加仓库、安装 Elasticsearch、配置文件修改、设置内存和文件描述符、启动和验证 Elasticsearch,以及常见问题的解决方法。通过这些步骤,你可以快速搭建起这个强大的分布式搜索和分析引擎。
476 5

热门文章

最新文章

推荐镜像

更多
  • DNS