渣渣菜鸡为什么要看 ElasticSearch 源码?

前提

人工智能、大数据快速发展的今天,对于 TB 甚至 PB 级大数据的快速检索已然成为刚需,大型企业早已淹没在系统生成的浩瀚数据流当中。大数据技术业已集中在如何存储和处理这些海量的数据上。Elasticsearch 作为开源领域的后起之秀,从2010年至今得到飞跃式的发展。 Elasticsearch 以其开源、分布式、RESTFul API 三大优势,已经成为当下风口中“会飞的猪”。

在我的电脑本地写了几篇 ElasticSearch 的源码解析了,回过头来想想应该也写一篇为何我会去看它的源码?

为什么呢?下面我讲讲自己从接触搜索到现在看源码的过程!

第一次接触搜索

搜索,我们首先想到的是搜索引擎:Google、百度,这个就算是接触的最早的了。

我自己项目里面接触搜索是大二暑假那时练习的一个项目,里面用了 Solr,然后当时自己也稍微了解了下,并用在了项目里面。

第二次接触搜索

从第一次项目里面用到了搜索,后面自己对这方面就比较感兴趣。再一次接触搜索是实习的时候进公司。第一件事情就是被老大叫的去学习搭建 Elasticsearch 集群,于是乎,电脑就装了三个虚拟机,Elasticsearch 就一个个的装了起来了。也记录了博客下来:Elasticsearch 系列文章(二):全文搜索引擎 Elasticsearch 集群搭建入门教程,当时搭建的时候 ES 的版本才刚从 2.x 升级到 5.x 呢,截止本文时间 2018.08.04,现在 ES 版本已经是到 7.0 了,这版本升级是真的的快,这也说明了 ES 的活跃度很高,背后的开发工程师维护也快,侧面突出要去看它源码的重要性。

当时自己在本地测试搭建集群后,给分配了另外一个任务就是去了解 ES 中的自带分词、英文分词、中文分词的相同与差异、以及自己建立分词需要注意的点。于是乎:当时在公司 wiki 贡献了这篇文章:Elasticsearch 系列文章(一):Elasticsearch 默认分词器和中分分词器之间的比较及使用方法。这篇文章几乎已经把市面上所有的分词都写进去了,包括他们的相同点、不同点、如何使用、如何自定义分词器。

然后还有就是我同组的一个同学,她的任务就是 2.x 升级到 5.x 中 mapping 的大改变有哪些?后面我也看了她总结的文档,很详细!

在这次接触了 ES 后,因为我自己本地已经有环境了,所以自己测试了一些功能,给 ES 安装插件(IK、x-pack、支持 sql 的、),后面自己也去测试 ES 的索引、文档、REST API。

第三次接触搜索

由于是自己对其感兴趣,所以后面就去找了些相关的视频,比如:中华石衫的《Elasticsearch 顶尖高手系列-高手进阶篇》几个系列视频教程个人感觉还是不错的,看完这几个系列估计入门肯定是没有问题的。版权原因,不提供下载链接。

另外就是《Elasticsearch 权威指南》翻译的版本,翻译还没有全,可以去看看,讲得很详细的,市面上应该还没有哪本书讲的有这么清楚,如果英文不错的可以直接啃英文吧。

还有就是官网的文档了,非常非常详细,还有 demo,2.x 版本的是有中文的官方文档,可以凑合着看。

学习新东西,要学会先看官方文档,何况 Elasticsearch 的官方文档这么详细呢!

第四次接触搜索

后面实习的时候,又分配了公司中间件监控的两个模块:Elasticsearch 和 HBase 组件的监控。于是乎,再次有机会接触 Elasticsearch 了,这次主要还是利用 Elasticsearch 自带的 REST API :_cluster/health_cluster/stats_nodes_nodes/stats 去获取到集群的健康信息、节点信息(内存、CPU、网络、JVM等信息)。为了做这个项目自己当时也去找了网上很多类似的文章参考常用的监控指标和他们是怎么做监控的。我当时的任务主要还是采集信息,然后存到公司大项目的 influxdb 中,最后用 grafana 展示出来,后面我组的运维大佬给我看了监控大盘,界面挺酷炫的,哈哈哈,牛逼!

当时写的两篇博客:

1、Elasticsearch 系列文章(三):ElasticSearch 集群监控

2、Elasticsearch 系列文章(四):ElasticSearch 单个节点监控

取之网络,还之网络,希望给后面做类似任务的小伙伴给点参考意见!

再就是自己搭建 ELK(ElasticSearch, Logstash, Kibana)日志分析平台,然后玩了下!

搭建环境博客:Elasticsearch 系列文章(五):ELK 实时日志分析平台环境搭建

第五次接触搜索

后面就没怎么接触 ElasticSearch 了,一直忙着其他的东西。

实习辞职后,毕业出来找工作的那段日子,自己又花了一星期稍微过了一遍 《Elasticsearch 权威指南》 这本书,话说还帮我面试挺过不少关呢,哈哈哈!因为我项目里写了 Elasticsearch 的监控,如果你对 Elasticsearch 其他的不熟悉,面试官稍微问些其他关于这方面的,那就不知道就有点尴尬?了,所以还是准备了下。看完之后应付面试没多大的问题。

第六次接触

看起来我接触了 Elasticsearch 很久了,其实真正项目里面是没有用到 Elasticsearch 做过项目的,没有用到 Elasticsearch 的搜索做什么项目,于是自己当时找工作其实也打算找到工作后看能不能自己做个项目或者公司项目里面用用 Elasticsearch 呢?

结果在新公司新项目里,很快就用到了。只不过这次不是 Java 项目里面用了,而是和 GoLang 整合。不过 API 都差不多,多熟悉几次就很快上手了,关键还是要懂 Elasticsearch 如何构造 DSL 查询语句,这样再转换成 GO 里面的 API 就快了。

还有就是公司里刚好有个中科院研究生大佬,他就写过 Elasticsearch 这块的书籍《从 lucene 到 Elasticsearch 全文检索实战》,另外他的 CSDN 博客也很火,阅读量很高,感兴趣的可以买本书支持下。

中途自己遇到 Elasticsearch 实在不会的问题也会主动去找大佬咨询,然后大佬耐心教教我这个渣渣菜鸡,在文章这里感谢下大佬这段时间的关照。

萌生阅读源码的想法

既然接触了这么久的 Elasticsearch ,项目里用过,书籍也看过,虽然还不是很熟,但是如果看看它的源码是不是会让我对它的印象更深呢?

说干就干,晚上回家就从 GitHub clone 了源码在本地,那时刚好回家,就在火车上直接用 VS code 看了会源码,也没有在 ide 里 debug 起来。

写这篇文章的时候已经把 Elasticsearch 的整个启动流程(加载读取配置、加载插件等)、如何支持 REST API 看了下,后面会在下班后回家继续阅读源码,继续分享我的源码解析的。

有想法就去干,不尝试下,怎么知道适不适合你?

总结

其实阅读源码的主要原因还是自己感兴趣;另外就是这东西现在项目里确实也用到了,如果我对源码熟悉的话可能会对我的理解会更加透彻点;还有就是 Elasticsearch 确实火,公司几乎都用的,所以学习下还是有必要的。

关注我

转载请务必注明原创地址为:http://www.54tianzhisheng.cn/2018/08/24/why-see-es-code/

原文发布于微信公众号 - zhisheng(zhisheng_blog)

原文发表时间:2018-08-14

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏北京马哥教育

为一般人解说什么是Linux

本文是为那些没有接触过Linux系统的人写的。了解Linux系统对于一个技术来人员可谓是必须的(即便不是和计算机直接相关的),而对于广大普通用户而言,只了解Wi...

4789
来自专栏北京马哥教育

新手程序员必须要知道的10个秘密

初出茅庐的你带着仍残留墨香的毕业证书踏上工作岗位,马上就被书上没写的规则和各种繁杂的日常事务来了个下马威。这样的故事实在是司空见惯,编程工作也不例外。 没有几个...

3595
来自专栏FreeBuf

安全摘记 | 互联网安全小兵的日常

*本文原创作者:starshine,本文属FreeBuf原创奖励计划,未经许可禁止转载 生活不只有眼前的苟且,还有诗和甲方。于是,我来到了甲方,成为了一个互联网...

2019
来自专栏python3

python简介

1.系统编程:提供API(Application Programming Interface,应用程序编程接口),能方便地进行系统维护和管理,Linux下标志性...

1152
来自专栏腾讯架构师的专栏

TCS 弹性计算平台:像工匠一样耕耘云计算

2016年腾讯架构平台部相继推出了两朵云:云存储和云接入,截至目前,弹性平台运营的计算力,服务了公司图片压缩、视频转码、离线计算和AI计算等多个计算场景,前不久...

4350
来自专栏阮一峰的网络日志

Google遵循的软件行为准则

昨天,我写了Google发现的十条真理,其中第六条就是著名的"不干坏事,也能成功"(Don't be evil)。 那么,什么样的事情算是"坏事"呢? Goog...

3115
来自专栏Golang语言社区

大型网站的架构设计图分享-转

近段时间以来,通过接触有关海量数据处理和搜索引擎的诸多技术,常常见识到不少精妙绝伦的架构图。除了每每感叹于每幅图表面上的绘制的精细之外,更为架构图背后所隐藏的设...

6359
来自专栏惶心 - 技术博客

用一年的时间,去遇见

白色而透明的屏幕里,像素点时刻变换着颜色。你看不见的黑暗里,只有风扇快速转动,发出微弱的响声。

1669
来自专栏区块链

纺织人快看:如果微信这个开关没关,你的手机会越来越卡!

微信可以说是当今最流行的社交软件 随时随地都能看到一群年轻人 没事就刷朋友圈、看小视频 每每看到自已喜欢的图片 都会保存在手机 这样每天微信都会存储大量的照片和...

2209
来自专栏51CTO技术栈的专栏

风靡全国,日活8000万,《王者荣耀》后台技术架构演进!

这个曾经在端游时代主导搭建 RTS 游戏《霸三国》框架的技术团队,在转型做 MOBA 手游《王者荣耀》后为游戏提供了巨大的支持,但这个过程也并非一帆风顺。

1.9K0

扫码关注云+社区

领取腾讯云代金券