对于源码分析,我们先还是从最外层域用户交互这一块开始,看到源码里面有一个client(客户端)的包:
点开查看详细类文件结构:
首先我们可以看到AdminClient接口,里面提供两个方法:
1) cluster(),产生一个允许从集群中执行action或操作的client;
2) indices(),产生一个允许从索引中执行action或操作的client。
查看树结构关联:
可以看出,AdminClient接口有两个实现类,分别为org.elasticsearch.client.AdminClient.NodeAdminClient和org.elasticsearch.client.transport.support.InternalTransportAdminClient。
NodeAdminClient有一个带有@Inject注解的构造器,并实现了接口AdminClient的两个方法。@Inject导致了一个直接的后果:你只能通过被@Inject标注的构造器生成实例。indices()和cluster()覆盖了AdminClient的同名方法,分别返回NodeIndicesAdminClient和NodeClusterAdminClient对象。
NodeAdminClient会继承父类org.elasticsearch.common.component.AbstractComponent的nodeName()方法用以获取当前节点的名称。
org.elasticsearch.client.transport.support.InternalTransportAdminClient类
InternalTransportAdminClient其实与NodeAdminClient类似,只是它的indices()和cluster()分别返回的是InternalTransportIndicesAdminClient和InternalTransportClusterAdminClient。
NodeAdminClient和InternalTransportAdminClient均没有子类,所以只有当我们需要用到NodeIndicesAdminClient、NodeClusterAdminClient、InternalTransportIndicesAdminClient或InternalTransportClusterAdminClient时,才考虑创建这两个类的实体。
此外,org.elasticsearch.client.Client接口为从集群中执行action或operation提供了一站式接口,这里的所有操作都是自然而然地异步执行的,每个action或operation都有两种风格,一种是简单地返回一个org.elasticsearch.action.ActionFuture,另一种是访问一个org.elasticsearch.action.ActionListener。你可以在org.elasticsearch.node.Node启动时取得一个Client,也可以使用org.elasticsearch.client.transport.TransportClient远程连接一个或多个节点。
程序猿行业技术生活交流群:181287753(指尖天下),欢迎大伙加入交流学习。
- 大小: 205.3 KB
- 大小: 9.8 KB
- 大小: 20.5 KB
- 大小: 21.3 KB
分享到:
相关推荐
本实例提供的"安卓Android源码——客户端连接服务器并交互实例.zip"文件,将帮助我们深入理解这一过程。下面我们将详细探讨相关的知识点。 1. **网络通信基础**: - 客户端-服务器模型:在Android应用中,客户端...
《安卓Android源码——客户端文档及demo_20130328》 这篇文档主要探讨了2013年3月28日时,Android操作系统客户端的源码及其相关文档与示例代码。Android作为全球最广泛使用的移动操作系统,其源码的开放性为开发者...
"安卓Andriod源码——客户端文档及demo_(20130328).zip" 提供了一个早期版本的Android源码以及相关的客户端文档和示例代码,这对于开发者深入学习Android平台的内部工作原理和客户端应用开发具有重要意义。...
【Android源码分析——andricoFacebook客户端】 在深入解析安卓Android源码——andricoFacebook客户端之前,首先要理解Android操作系统的基本架构。Android是一个基于Linux内核的开源移动操作系统,它为开发者提供...
《局域网聊天系统——客户端实现详解》 在IT领域,局域网聊天系统的开发是一项基础而实用的技术实践。本文将深入探讨一个用C++语言编写的局域网聊天系统客户端,旨在帮助初学者理解其核心概念和技术要点。 C++是一...
【Android源码——网易客户端源码.zip】是一个包含Android应用开发相关知识的压缩包,主要提供了网易客户端的源代码,让我们有机会深入理解大型新闻客户端的实现机制。在探索这个源码的过程中,我们可以学习到以下几...
【Android源码解析——Oschina客户端】 在深入解析安卓Android源码——Oschina客户端之前,我们首先要了解Android系统的基本架构。Android是一个开源的操作系统,主要由Linux内核、库层、应用框架以及应用程序四大...
淘宝客户端源码的结构通常是模块化的,每个功能模块都有独立的代码库,如网络通信模块、UI模块、数据存储模块等。这种设计有利于代码的维护和复用,也有助于团队协作。学习源码时,可以关注主工程如何管理和协调各个...
不过,由于Facebook的源码并不公开,这份"Android源码——Facebook客户端.zip"可能是社区的逆向工程或者模拟实现,实际内容可能与真实Facebook客户端有所差异。真正的学习和理解仍需结合官方文档和最佳实践。
《深入剖析Android源码——以博客园客户端为例》 Android作为一个开源的操作系统,其源码是开发者探索移动应用开发的宝库。博客园客户端作为一款广受欢迎的应用,其源码同样蕴含了丰富的Android开发知识。本文将从...
"安卓Android源码——微博客户端源代码.zip"这个标题表明我们讨论的是一个与Android操作系统相关的项目,具体来说是微博客户端的应用程序源代码。这通常意味着我们可以深入理解如何在Android平台上构建一个社交媒体...
这是我的博客:jQuery作前台,Python3-Flask作后端的全栈开发——数据交互方式 https://blog.csdn.net/winerchopin/article/details/87886777#comments 讲解使用胡代码1
《Android无线点餐系统——客户端实现详解》 在信息技术飞速发展的今天,Android无线点餐系统已成为餐饮行业的必备工具,极大地提升了服务效率和客户体验。本文将深入探讨该系统客户端的实现,涵盖设计思路、主菜单...
1. 客户端:基于Android操作系统的智能家居客户端,负责与家居设备交互,收集家居设备的信息和数字视频,并将其传输到云服务器上。 2. 云服务器:阿里云服务器,负责存储和处理家居设备的信息和数字视频,并提供...
在Wireshark数据包分析实战第三版中,我们聚焦于一个特定的问题——客户端延迟,这在通信缓慢的场景中是一个常见的挑战。通过分析一个名为"latency3.pcap"的捕获文件,我们可以深入理解这一现象。在图11-24所示的...
分析微博客户端的源码,我们可以了解如何划分功能模块,以及如何构建组件之间的通信机制。 9. **国际化和本地化**:作为面向全球用户的社交应用,微博客户端可能会支持多语言环境,这涉及到字符串资源的管理、布局...
【安卓Android源码——经典源码之博客园客户端】 这篇解析将深入探讨安卓Android源码中的博客园客户端应用。博客园客户端是安卓平台上一个流行的开源项目,它为开发者提供了研究和学习Android应用开发的宝贵资源。...
《深入剖析Android源码——以饭否客户端为例》 Android作为全球最受欢迎的移动操作系统,其源码对于开发者来说,既是挑战也是宝藏。本篇将基于"Android源码——饭否客户端源码.zip"这一资源,深入探讨Android源码在...