elasticserach 索引删除 源码分析
索引的构成
在看IndicesService服务中移除索引的前提,先了解一个Index类的构成,也就是索引的一些基本信息,代码贴图如下:

主要的信息就两个:一个是name,表示索引名称,一个是uuid,表示索引的唯一标识。ok,了解这个之后。我们开始表述我们的正题,索引是怎么删除的,要删除哪些信息。
index删除过程
在indicesService类中的removeIndex方法进行索引的删除操作, 执行流程如下:
1:创建一个Map<String,IndexService>类型的HashMap叫做newIndices,将indicesService中indices中的数据复制到newIndices中
2:通过uuid将newIndices中的IndexService移除,并返回IndexService对象
3:通过unmodifiableMap方法,将newIndices 赋值给indices,并将indices设置为final。
备注: unmodifiableMap是一个java内置方法,将指定的对象设置为final并返回新的对象。这里indices初始化是一个volatile(不懂volatile可查阅具体资料),通过一个新的map对象,也就是newIndices来保证indices操作的线程安全.因为newIndices是线程内部,属于线程私有。
4:关闭分片,将分片的状态置为close,将移除原因设置为DELETE
5:关闭bitsetFilterCache,indexCache,indexFieldData,mapperService,refreshTask,fsyncTask,trimTranslogTask,globalCheckpointTask这些服务
6:执行删除操作,如果删除失败,将索引添加到pendingDeletes 中,表示当前索引已经挂起,为不可用的状态。
备注:执行删除主要是文件删除操作,删除的文件是我们配置的节点data目录下,每个目录${basepath}/nodes/0/indices下,basepath是我们在安装集群时创建的路径,而nodes/0/indices是默认路径,在indices中以index的uuid为文件夹名称的文件夹是所有的数据目录,在删除的时候就是通过uuid来删除这个目录。这个目录我查看的是5.1.1的版本。

要删除的信息就是上面截图中的文件夹。这也是我们数据的主要存储目录
7:删除所有的index元数据信息(这个起到一个保护机制,保证删除索引不会重新作为一个新的空索引导入,所以彻底删除掉。但是后面的ES版本应该会将元数据信息做一个备份或者标志一个已删除的状态,而不是全部删除清空)
ok,索引的删除操作就是这样的,在后面会继续分析这服务的其他操作,索引的创建,分片等elasticsearch的一些知识,中间还会涉及到一些内置的配置信息,会告诉你通过这些配置我们可以起到怎样的作用,怎么优化elasticseach等。
elasticserach 索引删除 源码分析的更多相关文章
- shinx索引部分源码分析——过程:连接到CSphSource对应的sql数据源,通过fetch row取其中一行,然后解析出field,分词,获得wordhit,最后再加入到CSphSource的Hits里
CSphSource 数据源 CSphSource_XMLPipe2-XML文件获取数据 CSphSource_SQL-SQL(MySQL)获取数据 CSphIndex 索引器 派生类CSphInde ...
- Mybatis 源码分析--crud
增加源码分析-insert() --------------------------------------------------------------------- public int ins ...
- LinkedList 源码分析(JDK 1.8)
1.概述 LinkedList 是 Java 集合框架中一个重要的实现,其底层采用的双向链表结构.和 ArrayList 一样,LinkedList 也支持空值和重复值.由于 LinkedList 基 ...
- sphinx源码分析总结
http://www.cnblogs.com/bonelee/p/6667955.html shinx索引部分源码分析——过程:连接到CSphSource对应的sql数据源,通过fetch row取其 ...
- Solr4.8.0源码分析(17)之SolrCloud索引深入(4)
Solr4.8.0源码分析(17)之SolrCloud索引深入(4) 前面几节以add为例已经介绍了solrcloud索引链建索引的三步过程,delete以及deletebyquery跟add过程大同 ...
- Solr4.8.0源码分析(16)之SolrCloud索引深入(3)
Solr4.8.0源码分析(16)之SolrCloud索引深入(3) 前面两节学习了SolrCloud索引过程以及索引链的前两步,LogUpdateProcessorFactory和Distribut ...
- Solr4.8.0源码分析(13)之LuceneCore的索引修复
Solr4.8.0源码分析(13)之LuceneCore的索引修复 题记:今天在公司研究elasticsearch,突然看到一篇博客说elasticsearch具有索引修复功能,顿感好奇,于是点进去看 ...
- Solr4.8.0源码分析(10)之Lucene的索引文件(3)
Solr4.8.0源码分析(10)之Lucene的索引文件(3) 1. .si文件 .si文件存储了段的元数据,主要涉及SegmentInfoFormat.java和Segmentinfo.java这 ...
- Solr4.8.0源码分析(9)之Lucene的索引文件(2)
Solr4.8.0源码分析(9)之Lucene的索引文件(2) 一. Segments_N文件 一个索引对应一个目录,索引文件都存放在目录里面.Solr的索引文件存放在Solr/Home下的core/ ...
随机推荐
- linux_kernel_uaf漏洞利用实战
前言 好像是国赛的一道题.一个 linux 的内核题目.漏洞比较简单,可以作为入门. 题目链接: 在这里 正文 题目给了3个文件 分配是 根文件系统 , 内核镜像, 启动脚本.解压运行 boot.sh ...
- 如何在微软Windows平台上打造出你的Linux开发环境(转载)
如何在微软Windows平台上打造出你的Linux开发环境 投递人 itwriter 发布于 2013-12-10 11:18 评论(1) 有348人阅读 原文链接 [收藏] « » 英文原文: ...
- Oracle存储过程简单实例
转自 http://www.cnblogs.com/nicholas_f/articles/1526029.html /*不带任何参数存储过程(输出系统日期)*/create or replace p ...
- 结对编程——四则运算器(UI第十组)
博客目录: 一.问题描述 二.设计思路 三.UI开发过程 四.对接过程 ...
- 搭建企业级NFS网络文件共享服务说明[一]
1.1.0. 概述: 共享/NFS目录给整个192.168.25.0/24网段主机读写 man nfs 可以查看mount的信息 rpc端口111 nfs主端口2049 1.1.1. 搭建NFS环境 ...
- 解决华为交换机S5700无法解除ip/Mac绑定的问题
今天同事离职,需要解除他的个人笔记本Mac与ip的绑定 首先进入系统用户视图,然后进入vlanif4,解除151绑定 system-view interface vlanif 4 undo dhcp ...
- opengl redbook Fatal Error in XXXXXX pixel format with necessary capabilities not found
随便运行书中的一个程序aaindex.c时出现了下面的错误:pixel format with necessary capabilities not found 解决方法: http://www.ed ...
- Nginx-基础配置
正文 本文转载自:http://www.ha97.com/5194.html 文章经过我排版和润色再加工,更加易读.实在是了解nignx配置的基础好文章. 正文 定义Nginx运行的用户和用户组 us ...
- K8S Deployment 命令
创建 Deployment kubectl create -f https://kubernetes.io/docs/user-guide/nginx-deployment.yaml --record ...
- 自制年月选择插件 jquery.MyDatePicker v1.0beta
参数: el: null, //默认值和位置从哪个文本框取,传入jquery对象 ,默认为this 用于按钮引发文本框的focus事件来弹出 viewtype: 'month', //日期控件模式 默 ...