`
yucang52555
  • 浏览: 69842 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

elastciSearch源码分析——客户端交互模块

阅读更多
   对于源码分析,我们先还是从最外层域用户交互这一块开始,看到源码里面有一个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

    本实例提供的"安卓Android源码——客户端连接服务器并交互实例.zip"文件,将帮助我们深入理解这一过程。下面我们将详细探讨相关的知识点。 1. **网络通信基础**: - 客户端-服务器模型:在Android应用中,客户端...

    安卓Andriod源码——客户端文档及demo_(20130328).zip

    "安卓Andriod源码——客户端文档及demo_(20130328).zip" 提供了一个早期版本的Android源码以及相关的客户端文档和示例代码,这对于开发者深入学习Android平台的内部工作原理和客户端应用开发具有重要意义。...

    局域网聊天系统——客户端

    《局域网聊天系统——客户端实现详解》 在IT领域,局域网聊天系统的开发是一项基础而实用的技术实践。本文将深入探讨一个用C++语言编写的局域网聊天系统客户端,旨在帮助初学者理解其核心概念和技术要点。 C++是一...

    安卓Android源码——Oschina客户端.zip

    【Android源码解析——Oschina客户端】 在深入解析安卓Android源码——Oschina客户端之前,我们首先要了解Android系统的基本架构。Android是一个开源的操作系统,主要由Linux内核、库层、应用框架以及应用程序四大...

    安卓Android源码——andricoFacebook客户端.zip

    《安卓Android源码解析——深度探索andricoFacebook客户端》 在移动开发领域,安卓Android作为全球最广泛使用的操作系统之一,其源码分析是开发者提升技能、深入理解系统运行机制的重要途径。本篇文章将聚焦于...

    Android源码——淘宝客户端源码.zip

    淘宝客户端源码的结构通常是模块化的,每个功能模块都有独立的代码库,如网络通信模块、UI模块、数据存储模块等。这种设计有利于代码的维护和复用,也有助于团队协作。学习源码时,可以关注主工程如何管理和协调各个...

    Android源码——Facebook客户端.zip

    不过,由于Facebook的源码并不公开,这份"Android源码——Facebook客户端.zip"可能是社区的逆向工程或者模拟实现,实际内容可能与真实Facebook客户端有所差异。真正的学习和理解仍需结合官方文档和最佳实践。

    微信小程序——交互操作控件(截图+源码).zip

    微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作控件(截图+源码).zip 微信小程序——交互操作...

    jQuery作前台,Python3-Flask作后端的全栈开发——数据交互方式(项目代码)

    这是我的博客:jQuery作前台,Python3-Flask作后端的全栈开发——数据交互方式 https://blog.csdn.net/winerchopin/article/details/87886777#comments 讲解使用胡代码1

    IOS应用源码——新闻客户端应用.zip

    "IOS应用源码——新闻客户端应用.zip" 提供了一个完整的iOS新闻客户端应用的源代码,这对于iOS开发者,尤其是初学者来说,是一个宝贵的参考资料。这个压缩包包含了一个实际运行在iOS设备上的新闻阅读应用的所有组件...

    Android无线点餐系统——客户端的实现.doc

    《Android无线点餐系统——客户端实现详解》 在信息技术飞速发展的今天,Android无线点餐系统已成为餐饮行业的必备工具,极大地提升了服务效率和客户体验。本文将深入探讨该系统客户端的实现,涵盖设计思路、主菜单...

    基于android的智能家居系统设计——客户端及云服务器的实现毕设毕业论文.doc

    1. 客户端:基于Android操作系统的智能家居客户端,负责与家居设备交互,收集家居设备的信息和数字视频,并将其传输到云服务器上。 2. 云服务器:阿里云服务器,负责存储和处理家居设备的信息和数字视频,并提供...

    11.4.3 通信缓慢——客户端延迟 - Wireshark 数据包分析实战(第 3 版) - 知乎书店1

    在Wireshark数据包分析实战第三版中,我们聚焦于一个特定的问题——客户端延迟,这在通信缓慢的场景中是一个常见的挑战。通过分析一个名为"latency3.pcap"的捕获文件,我们可以深入理解这一现象。在图11-24所示的...

    安卓Android源码——微博客户端源代码.zip

    《安卓Android源码——微博客户端源代码》是一个深入学习安卓应用开发的重要资源,它提供了微博客户端的完整源代码,让开发者能够直接查看、分析并学习其中的实现细节。这个源码包主要涵盖了以下几个核心知识点: 1...

    Android源码——SipDroid客户端源码.zip

    《深入解析Android SipDroid客户端源码》 在Android平台中,SipDroid是一款开源的VoIP(Voice over Internet Protocol)客户端,它利用了SIP(Session Initiation Protocol)协议来实现网络电话功能。SipDroid的...

    Android源码——新浪微博客户端源码.zip

    分析微博客户端的源码,我们可以了解如何划分功能模块,以及如何构建组件之间的通信机制。 9. **国际化和本地化**:作为面向全球用户的社交应用,微博客户端可能会支持多语言环境,这涉及到字符串资源的管理、布局...

    asp.net中TextBox获得焦点和失去焦点——客户端JavaScript事件

    总结来说,ASP.NET中的TextBox可以通过JavaScript的`focus`和`blur`事件实现丰富的客户端交互。这些事件允许我们在用户开始输入时执行预处理,而在用户离开文本框时执行后处理,从而提升用户体验并实现动态验证等...

    PHP人才房产类网站实例开发源码——phpcms房产模块.zip

    本资源"PHP人才房产类网站实例开发源码——phpcms房产模块.zip"提供了一个基于PHP的房产类网站开发实例,其中的核心是phpcms2007的房产模块。phpcms是一款功能强大的内容管理系统,它允许开发者快速搭建和管理网站,...

    安卓Android源码——精典源码之博客园客户端.zip

    【安卓Android源码——经典源码之博客园客户端】 这篇解析将深入探讨安卓Android源码中的博客园客户端应用。博客园客户端是安卓平台上一个流行的开源项目,它为开发者提供了研究和学习Android应用开发的宝贵资源。...

    Android源码——豆瓣手机客户端源码.7z

    本篇将基于"Android源码——豆瓣手机客户端源码.7z"这一资源,深入探讨Android开发中的核心概念与技术,通过解析豆瓣手机客户端的源码,来揭示Android应用的构建之道。 首先,我们要理解Android应用程序的基本架构...

Global site tag (gtag.js) - Google Analytics