ElasticSearch基础概念

Elasticsearch的Head插件安装

Elasticsearch在Centos 7上的安装常见的问题

使用场景:比如分库的情况下,你想统计所有数据的报表,就把所有数据都放在ElasticSearch上

关系型数据库 ElasticSearch
数据库Database 索引index,支持全文检索
表Table 类型Type
数据行Row 文档Document
数据列Column 字段Field
模式Schema 映射Mapping

用关系型数据库就会想到建立一张User表,再建字段等,

而在Elasticsearch的文件存储,Elasticsearch是面向文档型数据库,一条数据在这里就是一个文档,用JSON作为文档序列化的格式

在ES6.0之后,已经不允许在一个index下建不同的Type了,一个index下只有一个Type(以后版本中Type概念会去掉,可以直接把index类比成Table)

节点Node:

  一个ElasticSearch运行的实列,集群构成的单元

集群Cluster:

  由一个或多个节点组成,对外提供服务  

Elasticsearch实现原理-倒排索引

ElasticSearch是基于倒排索引实现的

倒排索引(Inverted Index)也叫反向索引,有反向索引必有正向索引。

通俗地来讲,正向索引是通过key找value,反向索引则是通过value找key。

倒排索引—单词词典

单词词典(Term Dictionary)是倒排索引的重要组成部分。

——记录所有文档的单词,一般都比较大

——记录单词到倒排列表的关联信息(这个单词关联了哪些文档)

倒排索引—排序列表

倒排列表(Posting List)记录了单词对应文档的集合,由倒排索引项(Posting)组成

倒排索引项(Posting)主要包含如下信息

—文档Id,用于获取原始信息

—单词频率(TF,Term Frequency),记录该单词在文档中出现的次数,用于后序相关算分

—位置(Position),记录单词在文档中的分词位置,用于做词语搜索(Phrase Query)

—偏移(Offset),记录单词在文档的开始和结束位置,用于高亮显示

分词

搜索引擎的核心是倒排索引,而倒排索引的基础就是分词。所谓分词可以简单理解为将一个完整的句子切割为一个个单词的过程。也可以叫文本分析,在es称为Analysis。

如文本:elasticSearch是最流行的搜索引擎

分词结果:elasticSearch 流行 搜索引擎

分词器是es中专门处理分词的组件,英文为Analyzer,它的组成如下

Character Filters:针对原始文本特殊处理,比如除html特殊符

Tokenizer:将原始文本按照一定规则切分为单词

TokenFilters:针对tokenizer处理的单词就行在加工,比如转小写,删除或新增处理(比如中文中的  这 呢 无实意的词)

Analyze API

es提供了一个测试分词的API接口,方便验证分词效果,endpoint是_analyze

—可以直接指定analyze测试

—可以直接指定索引中的字段进行测试

—可以自定义分词器进行测试

文档映射Mapping

Mapping类似数据库中的表结构定义,主要作用如下:

—定义Index下的字段名(Field Name)

—定义字段的类型,比如数值型、字符串型、布尔型等

—定义倒排索引相关的配置,比如是否索引、记录position等

Dynamic Mapping

es可以自动识别文档字段类型,从而降低用户使用成本

SearchAPI介绍和相关性算分

es中存储的数据进行查询分析,endpoint为_search

查询主要有两种形式

1)URI Search

操作简单,方便通过命令进行测试

但 仅包含部分查询语法

GET /indexname/_search?q=user:xx

2)Request Body Search

es提供的完备查询语法Query DSL(Domain Specific Language)

GET /indexname/_search

{
  "query": {
    "term": {
      "user": "xx"
    }
  }
}

相关算分

相关算分是指文档与查询语句直接的相关度,英文为relevance

  通过倒排索引可以获取与查询语句相匹配的文档列表,那么如何将最符合用户查询的文档放到前列呢

  本质是一个排序问题,排序的依据是相关算分

ES目前主要有两个相关性算分模型

  TF/IDF模型

  BM25模型 5.x之后的默认模型

BM25相比TF/IDF的一大优化是降低了TF(Term Frequency单词频率)在过大时的权重

相关算分是shard与shard间是相互独立的,也就意味着一个Term的IDF等值在不同shard上是不同的。文档的相关算分和它所处的shard有关

在文档数量不多时 会导致相关算分严重不准的情况发生

解决办法

  —设置分片数是一个,从根本排除问题,在文档数据量不多时可以考虑该方法,(百万到千万)

  —二是使用DFS Query Then Ftech查询方式

Elasticsearch分布式特性

es支持集群模式,是一个分布式系统,好处是

—1)增加系统容量:内存、磁盘,使es集群可以支持PB级的数据

如何将数据分布在所有节点上

  —引入分片 Shard解决问题

分片是ES支持PB级数据的基石

  —分片存储了部分数据,可以分部在任意节点上

  —分片数在索引创建时指定且后序不允许再更改(即使你后面新增了也用不到),默认5个

  —分片有主分片和副本分片之分,以实现数据的高可用

es集群由多个es实列组成

  —不同集群通过集群名字来区分,可通过cluster.name修改,默认为elasticSearch

  —每个ES实列本质是一个JVM进程,且有自己的名字,通过node.name修改

Master Node:Master节点通过集群中所有的节点选举产生,可以被选举的节点称为master-eligible节点,

      相关配置如下:node.master:true

Coordinating Node:处理请求的节点为Coordinating节点,该节点为所有节点默认角色,不能取消

            作用是把请求路由到正确的节点处理,比如创建索引请求到master节点

Data Node:存储数据的节点即为data节点,默认节点都是data类型,相关配置如下:node.data.true

—2)提供系统可用性:即部分节点停止服务,整个集群依然可以正常服务

提高系统可用性

服务可用性

  —两个节点情况下,允许其中一个节点停止服务  

数据可用性

  —引入副本(Replication)解决

  —每个节点上都有完备的数据

复制分片的意义在于容错性,当一个节点挂了,另一个节点上的分片可以代替挂掉节点上的分片

故障转移

一:

二:

三:

文档到分片的映射算法

es通过如下公式计算文档到对应的分片 -shard=hash(routing)%number_of_primary_shards

hash算法保证可以将数据均匀的分散在分片中

routing是一个关键参数,默认是文档id,也可以自行指定

number_of_primary_shards是主片分数(该算法与主片分数相关,这也是分片数量一旦确定就不能修改的原因)

脑裂问题

在上述第一步的时候 node2和node3选举node2为master节点了时候,此时会更新cluster state

此时node1节点网络恢复了,node1自己组成集群后,也会更新cluster state

此时:同一个集群有两个master,而且维护不同的cluster state,网络恢复后 无法选择正确的master

解决方案:仅在可选举master-eligible节点数大于等于quorum时才可以进行master选举

        即使node1节点恢复了 ,可选节点数未达到quorum,不选举

学习下ElasticSearch的更多相关文章

  1. Elasticsearch学习总结 (Centos7下Elasticsearch集群部署记录)

    一.  ElasticSearch简单介绍 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticse ...

  2. 算是休息了这么长时间吧!准备学习下python文本处理了,哪位大大有好书推荐的说下!

    算是休息了这么长时间吧!准备学习下python文本处理了,哪位大大有好书推荐的说下!

  3. (转载)Centos下Elasticsearch安装详细教程

    原文地址:http://www.cnblogs.com/sunny1009/articles/7874251.html Centos下Elasticsearch安装详细教程 1.Elasticsear ...

  4. 学习下新塘M0芯片的下载方法

    编程方式多种多样,解释这几种方式的原理,方便做后续的回答: 一.脱机 脱机的意思就是脱离PC机,有很多芯片必须连接PC才能烧录,比如某些FPGA芯片.MCU芯片.NAND Flash芯片等.脱机和在线 ...

  5. windows下elasticsearch配置及spring boot 简单demod的 整合

    学习过程: elasticsearch 下载安装 elasticsearch-head 安装 spring boot 下elasticsearch的配置 使用ElasticsearchReposito ...

  6. Windows下ElasticSearch及相关插件的安装

    (1)在官网下载ElasticSearch压缩包.这里我下载的是elasticsearch-1.7.1(下载地址:https://download.elastic.co/elasticsearch/e ...

  7. Centos下Elasticsearch安装详细教程

    Centos下Elasticsearch安装详细教程 1.Elasticsearch简介 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于 ...

  8. windows下elasticsearch安装ik分词器后无法启动

    windows下elasticsearch安装ik分词器后启动报如下图错误: 然后百度说是elasticsearch路径有空格,一看果然我的路径有空格,然后重新换个路径就好了.

  9. RPC 框架要实现这个功能,我们可以使用泛化调用。那什么是泛化调用呢?我们带着这个问题,先学习下如何在没有接口的情况下进行 RPC 调用。

    RPC 框架要实现这个功能,我们可以使用泛化调用.那什么是泛化调用呢?我们带着这个问题,先学习下如何在没有接口的情况下进行 RPC 调用.

随机推荐

  1. 微信小程序路由跳转

    微信小程序路由跳转 1.wx.switchTab(Object object) 这里的tabBar是底下的导航栏指定的页面, 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面 参数 O ...

  2. postman动态数据获取

    1.以获取token(JWT)和uid为例 2.在登录接口的tests中写入代码(因为登录接口报文信息中有返回JWT和uid) 3.在其他接口中需要用到JWT和uid的地方设置变量{{JWT}}和{{ ...

  3. postman常用断言

    1.Code is 200 断言状态码是200 2.contains string 断言respoonse body中包含string 3.json value check (检查JSON值)

  4. powershell(一)

    Windows powershell是一种命令行外壳程序和脚本环境,它内置在win7以上版本的操作系统中,使命令行用户和脚本编写者可以利用.NET Framework的强大功能.powershell程 ...

  5. vc++源码免杀特殊技巧

    一.Debug 和 Release 编译方式的区别: Debug 通常称为调试版本,它包含调试信息,并且不作任何优化,便于程序员调试程序.Release 称为发布版本,它往往是进行了各种优化,使得程序 ...

  6. 05 Node.js学习笔记之发送文件数据

    这章学习在NodeJs中如何将Html文件发送到客户端上,以及定义Content-Type内容类型 //1.载入http和fs模块 var http=require("http") ...

  7. JAVA NIO udp 实现 群转发

    场景很简单,就是多个客户端通过udp,连接到服务器(其实是无连接的,就是服务器保存了客户端的ip信息).然后通过udp协议先服务器发送消息,然后服务器在通过udp转发在各个客服端. 这个是不是 观察者 ...

  8. Newtonsoft—Json.NET常用方法简述

    Json.NET常用方法汇总(可解决日常百分之90的需求) 0.Json.NET基础用法 首先去官网下载最新的Newtonsoft.Json.dll(也可以使用VS自带的NuGet搜索Json.NET ...

  9. CasperJS 前端功能测试

    CasperJS 是一个开源的导航脚本和测试组件.它提供实用的高级函数.方法和语法糖,可完成以下任务: 对浏览导航步骤的定义和排序 填写和提交表单 点击和跟踪链接 获取页面快照(或者页面中的某部分) ...

  10. OracleService服务不见了|OracleServiceXE服务没有了

    服务里面本来应该有OracleService的(或者是Express版的OracleServiceXE),而服务列表没有此服务项,而启动数据库时出现: TNS监听程序当前无法识别连接描述符中请求的服务 ...