对于源码分析,我们先还是从最外层域用户交互这一块开始,看到源码里面有一个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内核的开源移动操作系统,它为开发者提供...
"Android源码——网易客户端源码.7z" 提供了这样的宝贵资源,让我们有机会一窥网易客户端背后的实现细节。这份源码不仅能够帮助开发者了解大型应用的设计模式和最佳实践,还能够加深对Android系统运行机制的理解。 ...
这篇博客"axis2学习——客户端的开发"主要探讨了如何使用Axis2来创建和操作Web服务的客户端。 首先,让我们了解什么是Apache Axis2。Axis2是Axis1的下一代版本,它提供了更高效、更灵活的服务框架。它是基于模块化...
【安卓Android源码——Facebook客户端.zip】是一个包含Facebook客户端源代码的压缩文件,这对于学习和研究Android应用开发,特别是社交应用的实现具有重要的价值。在这个压缩包中,开发者可以深入理解Facebook应用...
【Android源码——网易客户端源码.zip】是一个包含Android应用开发相关知识的压缩包,主要提供了网易客户端的源代码,让我们有机会深入理解大型新闻客户端的实现机制。在探索这个源码的过程中,我们可以学习到以下几...
标题中的“android 应用 源代码——客户端”表明这是一个关于Android客户端应用程序的源码集合,这将涵盖多种功能和设计模式,对开发者来说极具价值。描述中提到,这个压缩包包含几十个电子书和源代码,都是在最近...
【Android源码解析——Oschina客户端】 在深入解析安卓Android源码——Oschina客户端之前,我们首先要了解Android系统的基本架构。Android是一个开源的操作系统,主要由Linux内核、库层、应用框架以及应用程序四大...
### 嵌入式浏览器的源码分析——总体设计与HTML解析 #### 一、嵌入式浏览器的现状与发展 随着信息技术的飞速发展,嵌入式产品在人们的日常生活中扮演着越来越重要的角色。特别是在互联网普及之后,对于嵌入式设备...
淘宝客户端源码的结构通常是模块化的,每个功能模块都有独立的代码库,如网络通信模块、UI模块、数据存储模块等。这种设计有利于代码的维护和复用,也有助于团队协作。学习源码时,可以关注主工程如何管理和协调各个...
不过,由于Facebook的源码并不公开,这份"Android源码——Facebook客户端.zip"可能是社区的逆向工程或者模拟实现,实际内容可能与真实Facebook客户端有所差异。真正的学习和理解仍需结合官方文档和最佳实践。
通过对SipDroid客户端源码的学习,开发者可以深入了解Android系统如何与网络、音频硬件交互,以及如何设计和优化一个实时通信应用。这不仅有助于提升开发者解决实际问题的能力,也为构建更高效、更稳定的VoIP应用...
《深入剖析Android源码——以博客园客户端为例》 Android作为一个开源的操作系统,其源码是开发者探索移动应用开发的宝库。博客园客户端作为一款广受欢迎的应用,其源码同样蕴含了丰富的Android开发知识。本文将从...
微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作...