如同磁铁吸引四周的铁粉,热情也能吸引周围的人,改变周围的情况。

Elastic日报 第444期 (2018-11-10)

1、jcseg:一个集成更多NLP相关功能的分词插件

     http://t.cn/R5iirZ2

2、PB级Elasticsearch集群的分片分配策略

     http://t.cn/EAfPVjT

3、使用Elasticsearch在地图上查找特定元素的方法

     http://t.cn/EAfP8Bi




编辑:  bsll

归档:https://elasticsearch.cn/article/6128

订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1、jcseg:一个集成更多NLP相关功能的分词插件

     http://t.cn/R5iirZ2

2、PB级Elasticsearch集群的分片分配策略

     http://t.cn/EAfPVjT

3、使用Elasticsearch在地图上查找特定元素的方法

     http://t.cn/EAfP8Bi




编辑:  bsll

归档:https://elasticsearch.cn/article/6128

订阅:https://tinyletter.com/elastic-daily 收起阅读 »

elasticsearch冷热数据读写分离

Elasticsearch5.5冷热数据读写分离

前言

冷数据索引:查询频率低,基本无写入,一般为当天或最近2天以前的数据索引

热数据索引:查询频率高,写入压力大,一般为当天数据索引

当前系统日志每日写入量约为6T左右,日志数据供全线业务系统查询使用。

查询问题:

高峰时段写入及查询频率都较高,集群压力较大,查询ES时,常出现查询缓慢问题。

写入问题:

索引峰值写入量约为12w/s,且无副本。加上副本将导致索引写入速度减半、磁盘使用量加倍;不使用副本,若一个节点宕掉,整个集群无法写入,后果严重。

一、冷热数据分离

ES集群的索引写入及查询速度主要依赖于磁盘的IO速度,冷热数据分离的关键为使用SSD磁盘存储数据。

若全部使用SSD,成本过高,且存放冷数据较为浪费,因而使用普通SATA磁盘与SSD磁盘混搭,可做到资源充分利用,性能大幅提升的目标。

几个ES关键配置解读:

  • 节点属性(后续索引及集群路由分布策略均依据此属性)

    node.attr.box_type
    node.attr.zone
    ...

    elasticsearch.yml中可增加自定义配置,配置前缀为node.attr,后续属性及值可自定义,如:box_type、zone,即为当前es节点增加标签,亦可在启动命令时设置:bin/elasticsearch -d -Enode.attr.box_type=hot

  • 索引路由分布策略

    "index.routing.allocation.require.box_type": "hot"

    可在索引模板setting中设置,也可通过rest api动态更新。意义为索引依据哪个属性标签,对分片、副本进行路由分布。

    如我们对使用SSD作为存储介质的ES节点增加属性标签node.attr.box_type: hot,对其他SATA类ES节点增加属性标签node.attr.box_type: cool,将使当前索引的分片数据都落在SSD上。

es-1.png

后续对其索引配置更新为

  "index.routing.allocation.require.box_type": "cool"

将使索引分片从SSD磁盘上路由至SATA磁盘上,达到冷热数据分离的效果。

es-4.png

  • 集群路由分布策略(此策略比索引级路由策略权重高)

    目的:不将鸡蛋放进一个篮子中。

    "cluster.routing.allocation.awareness.attributes": "box_type"

    如上配置,新建索引时,索引分片及副本只会分配到含有node.attr.box_type属性的节点上。(该值可以为多个,如"box_type,zone")

    若集群中的节点box_type值只有一个,如只有hot,索引分片及副本会落在hot标签的节点上;若box_type值包括hot、cool,则同一个分片与其副本将尽可能不在相同的box_type节点上。

    此种场景使用于:同一个物理机含有多个ES节点,若这多个节点标签相同,使用此路由分布策略将尽可能保证相同物理机上不会存放同一个分片及其副本。

    "cluster.routing.allocation.awareness.force.box_type.values": "hot,cool"

    强制使分片与副本分离。若只有hot标签的节点,索引只有分片可以写入,副本无法分配;若有hot、cool两种标签节点,相同分片与其副本绝不在相同标签节点上。

es-2.png

二、数据读写分离

几点结论:

  • 若使当天索引及副本都写在SSD磁盘上,SSD磁盘使用量需20T以上,代价可能过高。(读写效率最高,但由于SSD节点肯定较少,读写都在相同节点上,节点压力会非常大)
  • 现有的方式,只使用普通的SATA磁盘存储,代价最低。(读写效率最低,即为当前运行状况)
  • 使用集群路由分配策略,SSD与SATA各存放1份数据,SSD磁盘需分配10T以上。(读写效率折中,均有较大提升)

若使用折中方案,另一个问题考虑:

SSD节点即有读操作,也有写操作,节点较少,压力还是较大,怎么实现mysql的主从模式,达到读写分离的效果?

目标:使主分片分配在SSD磁盘上,副本落在SATA磁盘上,读取时优先从副本中查询数据,SSD节点只负责写入数据。

实现步骤:

  1. 修改集群路由分配策略配置

    增加集群路由配置

    "allocation.awareness.attributes": "box_type",
    "allocation.awareness.force.box_type.values": "hot,cool"
  2. 提前创建索引

    提前创建下一天的索引,索引配置如下(可写入模板中):

    PUT log4x_trace_2018_08_11
    {
       "settings": {
         "index.routing.allocation.require.box_type": "hot",
         "number_of_replicas": 0
    }
    }

    此操作可使索引所有分片都分配在SSD磁盘中。

  3. 修改索引路由分配策略配置

    索引创建好后,动态修改索引配置

    PUT log4x_trace_2018_08_11/_settings
    {
     "index.routing.allocation.require.box_type": null,
     "number_of_replicas": 1
    }

es-5.png

  1. 转为冷数据

    动态修改索引配置,并取消副本数

    PUT log4x_trace_2018_08_11/_settings
    {
     "index.routing.allocation.require.box_type": "cool",
     "number_of_replicas": 0
    }

es-6.png

继续阅读 »

Elasticsearch5.5冷热数据读写分离

前言

冷数据索引:查询频率低,基本无写入,一般为当天或最近2天以前的数据索引

热数据索引:查询频率高,写入压力大,一般为当天数据索引

当前系统日志每日写入量约为6T左右,日志数据供全线业务系统查询使用。

查询问题:

高峰时段写入及查询频率都较高,集群压力较大,查询ES时,常出现查询缓慢问题。

写入问题:

索引峰值写入量约为12w/s,且无副本。加上副本将导致索引写入速度减半、磁盘使用量加倍;不使用副本,若一个节点宕掉,整个集群无法写入,后果严重。

一、冷热数据分离

ES集群的索引写入及查询速度主要依赖于磁盘的IO速度,冷热数据分离的关键为使用SSD磁盘存储数据。

若全部使用SSD,成本过高,且存放冷数据较为浪费,因而使用普通SATA磁盘与SSD磁盘混搭,可做到资源充分利用,性能大幅提升的目标。

几个ES关键配置解读:

  • 节点属性(后续索引及集群路由分布策略均依据此属性)

    node.attr.box_type
    node.attr.zone
    ...

    elasticsearch.yml中可增加自定义配置,配置前缀为node.attr,后续属性及值可自定义,如:box_type、zone,即为当前es节点增加标签,亦可在启动命令时设置:bin/elasticsearch -d -Enode.attr.box_type=hot

  • 索引路由分布策略

    "index.routing.allocation.require.box_type": "hot"

    可在索引模板setting中设置,也可通过rest api动态更新。意义为索引依据哪个属性标签,对分片、副本进行路由分布。

    如我们对使用SSD作为存储介质的ES节点增加属性标签node.attr.box_type: hot,对其他SATA类ES节点增加属性标签node.attr.box_type: cool,将使当前索引的分片数据都落在SSD上。

es-1.png

后续对其索引配置更新为

  "index.routing.allocation.require.box_type": "cool"

将使索引分片从SSD磁盘上路由至SATA磁盘上,达到冷热数据分离的效果。

es-4.png

  • 集群路由分布策略(此策略比索引级路由策略权重高)

    目的:不将鸡蛋放进一个篮子中。

    "cluster.routing.allocation.awareness.attributes": "box_type"

    如上配置,新建索引时,索引分片及副本只会分配到含有node.attr.box_type属性的节点上。(该值可以为多个,如"box_type,zone")

    若集群中的节点box_type值只有一个,如只有hot,索引分片及副本会落在hot标签的节点上;若box_type值包括hot、cool,则同一个分片与其副本将尽可能不在相同的box_type节点上。

    此种场景使用于:同一个物理机含有多个ES节点,若这多个节点标签相同,使用此路由分布策略将尽可能保证相同物理机上不会存放同一个分片及其副本。

    "cluster.routing.allocation.awareness.force.box_type.values": "hot,cool"

    强制使分片与副本分离。若只有hot标签的节点,索引只有分片可以写入,副本无法分配;若有hot、cool两种标签节点,相同分片与其副本绝不在相同标签节点上。

es-2.png

二、数据读写分离

几点结论:

  • 若使当天索引及副本都写在SSD磁盘上,SSD磁盘使用量需20T以上,代价可能过高。(读写效率最高,但由于SSD节点肯定较少,读写都在相同节点上,节点压力会非常大)
  • 现有的方式,只使用普通的SATA磁盘存储,代价最低。(读写效率最低,即为当前运行状况)
  • 使用集群路由分配策略,SSD与SATA各存放1份数据,SSD磁盘需分配10T以上。(读写效率折中,均有较大提升)

若使用折中方案,另一个问题考虑:

SSD节点即有读操作,也有写操作,节点较少,压力还是较大,怎么实现mysql的主从模式,达到读写分离的效果?

目标:使主分片分配在SSD磁盘上,副本落在SATA磁盘上,读取时优先从副本中查询数据,SSD节点只负责写入数据。

实现步骤:

  1. 修改集群路由分配策略配置

    增加集群路由配置

    "allocation.awareness.attributes": "box_type",
    "allocation.awareness.force.box_type.values": "hot,cool"
  2. 提前创建索引

    提前创建下一天的索引,索引配置如下(可写入模板中):

    PUT log4x_trace_2018_08_11
    {
       "settings": {
         "index.routing.allocation.require.box_type": "hot",
         "number_of_replicas": 0
    }
    }

    此操作可使索引所有分片都分配在SSD磁盘中。

  3. 修改索引路由分配策略配置

    索引创建好后,动态修改索引配置

    PUT log4x_trace_2018_08_11/_settings
    {
     "index.routing.allocation.require.box_type": null,
     "number_of_replicas": 1
    }

es-5.png

  1. 转为冷数据

    动态修改索引配置,并取消副本数

    PUT log4x_trace_2018_08_11/_settings
    {
     "index.routing.allocation.require.box_type": "cool",
     "number_of_replicas": 0
    }

es-6.png

收起阅读 »

elasticsearch优秀实践

Elasticsearch在数据湖中的地位

ElasticSearch_Data_PipeLine.png

  • 解读Elasticsearch:
    • 定位: ElasticSearch作为高扩展分布式搜索引擎,主要满足于海量数据实时存储与检索、全文检索与复查查询、统计分析。在如今大数据时代已经成为较popular的存储选择。
    • 特点: 由于Elasticsearch使用java作为开发语言、使用lucene作为核心处理索引与检索,尤其是使用简单的RestApi隐藏lucene的复杂,使得上手非常容易、海量数据索引与检索极快。es集群由于分片和副本的机制实现了自动容错、高可用、易扩展。
    • 开源且流行: Elasticsearch支持插件机制,社区活跃度高、官网更新频繁:提供了分析插件、同步插件、hadoop插件、es-sql插件、可视化插件、性能监控插件等,可以让我们站在巨人的肩膀上专心研究搜索需求
    • 不支持: 不支持频繁更新、关联查询、事务

最优部署架构

角色划分

  • es分为三种角色: master、client、data,三种角色根据elasticsearch.yml配置中node.master、node.data区分,分别为true false、false false、true true

  • master: 该节点不和应用创建连接,主要用于元数据(metadata)的处理,比如索引的新增、删除、分片分配等,master节点不占用io和cpu,内存使用量一般

  • client: 该节点和检索应用创建连接、接受检索请求,但其本身不负责存储数据,可当成负载均衡节点,client节点不占用io、cpu、内存

  • data: 该节点和索引应用创建连接、接受索引请求,该节点真正存储数据,es集群的性能取决于该节点个数(每个节点最优配置情况下),data节点会占用大量的cpu、io、内存

  • 各节点间关系: master节点具备主节点的选举权,主节点控制整个集群元数据。client节点接受检索请求后将请求转发到与查询条件相关的的data节点的分片上,data节点的分片执行查询语句获得查询结果后将结果反馈至client,在client对数据进行聚合、排序等操作将最终结果返回给上层请求

资源规划

  • master节点: 只需部署三个节点,每个节点jvm分配2-10G,根据集群大小决定
  • client节点: 增加client节点可增加检索并发,但检索的速度还是取决于查询所命中的分片个数以及分片中的数据量。如果不清楚检索并发,初始节点数可设置和data节点数一致,每个节点jvm分配2-10
  • data节点: ①单个索引在一个data节点上分片数保持在3个以内;②每1GB堆内存对应集群的分片保持在20个以内;③每个分片不要超过30G。
  • data节点经验:
    • 如果单索引每个节点可支撑90G数据,依此可计算出所需data节点数 。
    • 如果是多索引按照单个data节点jvm内存最大30G来计算,一个节点的分片保持在600个以内,存储保持在18T以内。
    • 主机的cpu、io固定,建议一台主机只部署一个data节点,不同角色节点独立部署,方便扩容
    • 每条数据保持在2k以下索引性能大约3000-5000条/s/data节点,增加data节点数可大幅度增加索引速率,节点数与索引效率的增长关系呈抛物线形状​

优秀的插件与工具

  • ik分词器: es默认分词器只支持英文分词,ik分词器支持中文分词

  • head数据查询工具: 类似于mysql的Navicat

  • logstash: 数据处理管。采样各种样式、大小的数据来源,实时解析和转换数据,选择众多输出目标导出数据

  • x-pack性能监控: 获取进程运行时资源与状态信息并存储至es中。可通过kibana查看es、logstash性能指标,试用版包括集群状态、延迟、索引速率、检索速率、内存、cpu、io、磁盘、文件量等还可以看到集群数据负载均衡时的情况。商用版还支持安全、告警等功能

  • kibana可视化工具: es的可视化工具可制作各种图表,可在该工具上执行dsl语句灵活操作es

  • es-sql: 用sql查询elasticsearch的工具,将封装复杂的dsl语句封装成sql

  • beats: 轻量级的数据采集工具,可监控网络流量、日志数据、进程信息(负载、内存、磁盘等),支持docker镜像的file采集

  • repository-hdfs: 该插件支持将es中离线数据转存至hdfs中长期存储

Elasticsearch优化经验

  • 参数调优

    • 开启内存锁,禁止swapping

      执行linux命令(临时生效)

      ulimit -l unlimited

      修改主机配置:/etc/security/limits.conf

      * soft memlock unlimited
      * hard memlock unlimited

      修改es配置:config/elasticsearch.yml

      bootstrap.memory_lock : true
    • 调大文件描述符数量

      执行linux命令(临时生效)

      ulimit -n 65535

      修改linux配置文件:/etc/security/limits.conf

      * soft nofile 65536
      * hard nofile 65536
    • 调大最大映射数

      执行linux命令(临时生效)

      sysctl -w vm.max_map_count=262144

      修改linux配置文件:/etc/sysctl.conf

      vm.max_map_count=262144
  • 索引配置

    • settings:{efresh_interval}:数据写入刷新间隔,默认1s,调整增加该值可以减少写入压力、增加写入速度,如设为60

      {
      "settings": {
        "refresh_interval": "60s"
      }
      }
    • mappings:{dynamic}: 禁止es自动创建字段,仅允许预先设定好的字段存入es,防止索引结构混乱

      {
       "mappings": {
         "mytype": {
           "dynamic": false
         }
       }
      }
    • _all:建议禁用

      {
      "_all": {
         "enable": false
        }
      }
    • keyword字段属性: ingore_above超过多少字符不写入,keyword一般用于精确查询,不能写入太长。

      {
      "name": {
          "type": "keyword",
          "ingore_above": 1000
       } 
      }
    • index属性:将 不作为查询字段的index值设为false

      {
        {
          "content": {
            "type": "text",
            "index": "false"
          }
        }
      }
  • JVM内存溢出处理

      ​ 防止es节点内存溢出后处于僵死状态且无法恢复,影响整个集群,在进程出现OOM时让进程宕掉,退出ES集群并引发告警,然后重启。
    
      ​ 在config/jvm.options中增加JVM启动参数:
            -XX:+ExitOnOutOfMemoryError

    该参数在jdk 1.8.0_92版本上线

  • 数据生命周期

    ​ es中的开启状态的索引都会占用堆内存来存储倒排索引,过多的索引会导致集群整体内存使用率多大,甚至引起内存溢出。所以需要根据自身业务管理历史数据的生命周期,如近3个月的数据开启用于快速查询;过去3-6月的数据索引关闭以释放内存,需要时再开启;超过6个月的可以生成快照保存至hdfs并删除索引,需要的时候从hdfs选择需要的索引恢复至集群中进行查询

    ​ 生产上常常使用logstash+索引模板的方式按照一定时间创建新的索引,例如按天创建索引,索引的命名可能是index-yyyy-mm-dd,每天生产不同的索引,清除历史数据时可直接关闭或删除

    ​ 需要注意的是:如何按照logstash默认的时间分割索引会有8个小时的误差,所以需要在logstash中将真实数据中的时间字段作为分割条件,保障按照业务时间分割索引

  • 路由查询

    ​ 在将数据写入es时,指定一个字段作为路由字段,es会将该字段进行hash计算写入到对应的分片上;查询时根据查询条件中的路由值,直接查找所在的分片,大幅度提高查询速度

    ​ 需要注意的是:路由字段必须是随机分布,否则会导致分片数据不平均引发的主机存储使用不平均,可以作为路由字段的:如业务流水、省份、系统编码等。

  • 过滤器

    ​ ES中的查询操作分为2种:查询(query)和过滤(filter),查询默认会计算每个返回文档的得分,然后根据得分排序;而过滤(filter)只会筛选出符合的文档,并不计算得分,且它可以缓存文档。单从性能考虑,过滤比查询更快而且更节省io资源。过滤适合在大范围筛选数据,而查询则适合精确匹配数据。开发时应先使用过滤操作过滤数据,然后使用查询匹配数据

  • 查询限制

    ​ 限制是为了保证es集群的稳定性。限制的内容包括:查询范围、单次查询数量等,过大的查询范围不仅会导致查询效率低,而且会是es集群资源耗费急剧增加,甚至引起es集群崩溃;单次查询数量限制是为了保证内存不会被查询内存大量占用,就是分页原理,es默认可以查询10000条数据

  • 批量导入

    ​ 如果你在做大批量导入,考虑通过设置 index.number_of_replicas: 0关闭副本。把每个索引的 index.refresh_interval 改到 -1关闭刷新。导入完毕后再开启副本和刷新

继续阅读 »

Elasticsearch在数据湖中的地位

ElasticSearch_Data_PipeLine.png

  • 解读Elasticsearch:
    • 定位: ElasticSearch作为高扩展分布式搜索引擎,主要满足于海量数据实时存储与检索、全文检索与复查查询、统计分析。在如今大数据时代已经成为较popular的存储选择。
    • 特点: 由于Elasticsearch使用java作为开发语言、使用lucene作为核心处理索引与检索,尤其是使用简单的RestApi隐藏lucene的复杂,使得上手非常容易、海量数据索引与检索极快。es集群由于分片和副本的机制实现了自动容错、高可用、易扩展。
    • 开源且流行: Elasticsearch支持插件机制,社区活跃度高、官网更新频繁:提供了分析插件、同步插件、hadoop插件、es-sql插件、可视化插件、性能监控插件等,可以让我们站在巨人的肩膀上专心研究搜索需求
    • 不支持: 不支持频繁更新、关联查询、事务

最优部署架构

角色划分

  • es分为三种角色: master、client、data,三种角色根据elasticsearch.yml配置中node.master、node.data区分,分别为true false、false false、true true

  • master: 该节点不和应用创建连接,主要用于元数据(metadata)的处理,比如索引的新增、删除、分片分配等,master节点不占用io和cpu,内存使用量一般

  • client: 该节点和检索应用创建连接、接受检索请求,但其本身不负责存储数据,可当成负载均衡节点,client节点不占用io、cpu、内存

  • data: 该节点和索引应用创建连接、接受索引请求,该节点真正存储数据,es集群的性能取决于该节点个数(每个节点最优配置情况下),data节点会占用大量的cpu、io、内存

  • 各节点间关系: master节点具备主节点的选举权,主节点控制整个集群元数据。client节点接受检索请求后将请求转发到与查询条件相关的的data节点的分片上,data节点的分片执行查询语句获得查询结果后将结果反馈至client,在client对数据进行聚合、排序等操作将最终结果返回给上层请求

资源规划

  • master节点: 只需部署三个节点,每个节点jvm分配2-10G,根据集群大小决定
  • client节点: 增加client节点可增加检索并发,但检索的速度还是取决于查询所命中的分片个数以及分片中的数据量。如果不清楚检索并发,初始节点数可设置和data节点数一致,每个节点jvm分配2-10
  • data节点: ①单个索引在一个data节点上分片数保持在3个以内;②每1GB堆内存对应集群的分片保持在20个以内;③每个分片不要超过30G。
  • data节点经验:
    • 如果单索引每个节点可支撑90G数据,依此可计算出所需data节点数 。
    • 如果是多索引按照单个data节点jvm内存最大30G来计算,一个节点的分片保持在600个以内,存储保持在18T以内。
    • 主机的cpu、io固定,建议一台主机只部署一个data节点,不同角色节点独立部署,方便扩容
    • 每条数据保持在2k以下索引性能大约3000-5000条/s/data节点,增加data节点数可大幅度增加索引速率,节点数与索引效率的增长关系呈抛物线形状​

优秀的插件与工具

  • ik分词器: es默认分词器只支持英文分词,ik分词器支持中文分词

  • head数据查询工具: 类似于mysql的Navicat

  • logstash: 数据处理管。采样各种样式、大小的数据来源,实时解析和转换数据,选择众多输出目标导出数据

  • x-pack性能监控: 获取进程运行时资源与状态信息并存储至es中。可通过kibana查看es、logstash性能指标,试用版包括集群状态、延迟、索引速率、检索速率、内存、cpu、io、磁盘、文件量等还可以看到集群数据负载均衡时的情况。商用版还支持安全、告警等功能

  • kibana可视化工具: es的可视化工具可制作各种图表,可在该工具上执行dsl语句灵活操作es

  • es-sql: 用sql查询elasticsearch的工具,将封装复杂的dsl语句封装成sql

  • beats: 轻量级的数据采集工具,可监控网络流量、日志数据、进程信息(负载、内存、磁盘等),支持docker镜像的file采集

  • repository-hdfs: 该插件支持将es中离线数据转存至hdfs中长期存储

Elasticsearch优化经验

  • 参数调优

    • 开启内存锁,禁止swapping

      执行linux命令(临时生效)

      ulimit -l unlimited

      修改主机配置:/etc/security/limits.conf

      * soft memlock unlimited
      * hard memlock unlimited

      修改es配置:config/elasticsearch.yml

      bootstrap.memory_lock : true
    • 调大文件描述符数量

      执行linux命令(临时生效)

      ulimit -n 65535

      修改linux配置文件:/etc/security/limits.conf

      * soft nofile 65536
      * hard nofile 65536
    • 调大最大映射数

      执行linux命令(临时生效)

      sysctl -w vm.max_map_count=262144

      修改linux配置文件:/etc/sysctl.conf

      vm.max_map_count=262144
  • 索引配置

    • settings:{efresh_interval}:数据写入刷新间隔,默认1s,调整增加该值可以减少写入压力、增加写入速度,如设为60

      {
      "settings": {
        "refresh_interval": "60s"
      }
      }
    • mappings:{dynamic}: 禁止es自动创建字段,仅允许预先设定好的字段存入es,防止索引结构混乱

      {
       "mappings": {
         "mytype": {
           "dynamic": false
         }
       }
      }
    • _all:建议禁用

      {
      "_all": {
         "enable": false
        }
      }
    • keyword字段属性: ingore_above超过多少字符不写入,keyword一般用于精确查询,不能写入太长。

      {
      "name": {
          "type": "keyword",
          "ingore_above": 1000
       } 
      }
    • index属性:将 不作为查询字段的index值设为false

      {
        {
          "content": {
            "type": "text",
            "index": "false"
          }
        }
      }
  • JVM内存溢出处理

      ​ 防止es节点内存溢出后处于僵死状态且无法恢复,影响整个集群,在进程出现OOM时让进程宕掉,退出ES集群并引发告警,然后重启。
    
      ​ 在config/jvm.options中增加JVM启动参数:
            -XX:+ExitOnOutOfMemoryError

    该参数在jdk 1.8.0_92版本上线

  • 数据生命周期

    ​ es中的开启状态的索引都会占用堆内存来存储倒排索引,过多的索引会导致集群整体内存使用率多大,甚至引起内存溢出。所以需要根据自身业务管理历史数据的生命周期,如近3个月的数据开启用于快速查询;过去3-6月的数据索引关闭以释放内存,需要时再开启;超过6个月的可以生成快照保存至hdfs并删除索引,需要的时候从hdfs选择需要的索引恢复至集群中进行查询

    ​ 生产上常常使用logstash+索引模板的方式按照一定时间创建新的索引,例如按天创建索引,索引的命名可能是index-yyyy-mm-dd,每天生产不同的索引,清除历史数据时可直接关闭或删除

    ​ 需要注意的是:如何按照logstash默认的时间分割索引会有8个小时的误差,所以需要在logstash中将真实数据中的时间字段作为分割条件,保障按照业务时间分割索引

  • 路由查询

    ​ 在将数据写入es时,指定一个字段作为路由字段,es会将该字段进行hash计算写入到对应的分片上;查询时根据查询条件中的路由值,直接查找所在的分片,大幅度提高查询速度

    ​ 需要注意的是:路由字段必须是随机分布,否则会导致分片数据不平均引发的主机存储使用不平均,可以作为路由字段的:如业务流水、省份、系统编码等。

  • 过滤器

    ​ ES中的查询操作分为2种:查询(query)和过滤(filter),查询默认会计算每个返回文档的得分,然后根据得分排序;而过滤(filter)只会筛选出符合的文档,并不计算得分,且它可以缓存文档。单从性能考虑,过滤比查询更快而且更节省io资源。过滤适合在大范围筛选数据,而查询则适合精确匹配数据。开发时应先使用过滤操作过滤数据,然后使用查询匹配数据

  • 查询限制

    ​ 限制是为了保证es集群的稳定性。限制的内容包括:查询范围、单次查询数量等,过大的查询范围不仅会导致查询效率低,而且会是es集群资源耗费急剧增加,甚至引起es集群崩溃;单次查询数量限制是为了保证内存不会被查询内存大量占用,就是分页原理,es默认可以查询10000条数据

  • 批量导入

    ​ 如果你在做大批量导入,考虑通过设置 index.number_of_replicas: 0关闭副本。把每个索引的 index.refresh_interval 改到 -1关闭刷新。导入完毕后再开启副本和刷新

收起阅读 »

社区日报 第443期 (2018-11-09)

1.Elasticsearch搜索词组,如何更准?
http://t.cn/EZFBj2R
2.基于日志实现数据同步和抽取方案
http://t.cn/EAygWTO
3.从es源码发现CPU热点线程
http://t.cn/EAygE0k

重磅活动:Elastic 中国开发者大会 2018明天开始啦!!!
http://conf.elasticsearch.cn/2018/shenzhen.html

编辑:金桥
归档:https://elasticsearch.cn/article/6125
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1.Elasticsearch搜索词组,如何更准?
http://t.cn/EZFBj2R
2.基于日志实现数据同步和抽取方案
http://t.cn/EAygWTO
3.从es源码发现CPU热点线程
http://t.cn/EAygE0k

重磅活动:Elastic 中国开发者大会 2018明天开始啦!!!
http://conf.elasticsearch.cn/2018/shenzhen.html

编辑:金桥
归档:https://elasticsearch.cn/article/6125
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

社区日报 第442期 (2018-11-08)

1、Elasticsearch运维宝典——监控实战篇
http://t.cn/EAwlTOI
2、mysql同步elasticsearch调研对比
http://t.cn/EAwlE6w
3、Elastic 搜索奖,表彰那些将 Elasticsearch 用于改造业务
http://t.cn/EZFFN7C

编辑:铭毅天下
归档: https://elasticsearch.cn/article/6124
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1、Elasticsearch运维宝典——监控实战篇
http://t.cn/EAwlTOI
2、mysql同步elasticsearch调研对比
http://t.cn/EAwlE6w
3、Elastic 搜索奖,表彰那些将 Elasticsearch 用于改造业务
http://t.cn/EZFFN7C

编辑:铭毅天下
归档: https://elasticsearch.cn/article/6124
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

社区日报 第441期 (2018-11-07)

1. 浅谈Elasticsearch基础与架构
http://t.cn/EwklpZS
2. Elasticsearch.net项目实战
http://t.cn/Ewklktq
3. Elasticsearch mapping 设计总结
http://t.cn/EwkjXZA
 
编辑:江水
归档:https://elasticsearch.cn/article/6123
订阅:https://tinyletter.com/elastic-daily
 
继续阅读 »
1. 浅谈Elasticsearch基础与架构
http://t.cn/EwklpZS
2. Elasticsearch.net项目实战
http://t.cn/Ewklktq
3. Elasticsearch mapping 设计总结
http://t.cn/EwkjXZA
 
编辑:江水
归档:https://elasticsearch.cn/article/6123
订阅:https://tinyletter.com/elastic-daily
  收起阅读 »

社区日报 第440期 (2018-11-06)

1.Beats 6.5 版本的大改进来了!集中配置管理、InfraUI、LogsUI,感兴趣的来看介绍!
http://t.cn/Ewg9RGi

2.(自备梯子)index 设置为 false 在 text 和 keyword 类型中表现是有差异的
http://t.cn/Ewg9FFq
3.(自备梯子)es 在电商中商品分析与排序的一点思路分享
http://t.cn/EwgCLtk


直播活动:
1.Elastic 官方直播分享活动:Introduction To ElasticStack,快来报名吧!
http://t.cn/EwgCtkP


编辑:rockybean
归档:https://elasticsearch.cn/article/6122
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1.Beats 6.5 版本的大改进来了!集中配置管理、InfraUI、LogsUI,感兴趣的来看介绍!
http://t.cn/Ewg9RGi

2.(自备梯子)index 设置为 false 在 text 和 keyword 类型中表现是有差异的
http://t.cn/Ewg9FFq
3.(自备梯子)es 在电商中商品分析与排序的一点思路分享
http://t.cn/EwgCLtk


直播活动:
1.Elastic 官方直播分享活动:Introduction To ElasticStack,快来报名吧!
http://t.cn/EwgCtkP


编辑:rockybean
归档:https://elasticsearch.cn/article/6122
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

社区日报 第439期 (2018-11-05)

1.elasticsearch 从 5.5.0升级到6.1版本的经历
http://t.cn/Ew8p7PD
2.你应该了解的5个logstash插件
http://t.cn/RrEiE3j
3.高效管理基于时间的索引
http://t.cn/REFMMZM

编辑:cyberdak
归档:https://elasticsearch.cn/article/6121
订阅:https://tinyletter.com/elastic-daily
 
继续阅读 »
1.elasticsearch 从 5.5.0升级到6.1版本的经历
http://t.cn/Ew8p7PD
2.你应该了解的5个logstash插件
http://t.cn/RrEiE3j
3.高效管理基于时间的索引
http://t.cn/REFMMZM

编辑:cyberdak
归档:https://elasticsearch.cn/article/6121
订阅:https://tinyletter.com/elastic-daily
  收起阅读 »

社区日报 第438期 (2018-11-04)

1.使用Filebeat和Elasticsearch Ingest管道解析csv文件。
http://t.cn/EwClFun
2.(自备梯子)Netflix数据管道的演变。
http://t.cn/EwCTGgw
3.(自备梯子)在Docker容器中运行bash或任何命令。
http://t.cn/EwCEbxU

编辑:至尊宝
归档:https://elasticsearch.cn/article/3699
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1.使用Filebeat和Elasticsearch Ingest管道解析csv文件。
http://t.cn/EwClFun
2.(自备梯子)Netflix数据管道的演变。
http://t.cn/EwCTGgw
3.(自备梯子)在Docker容器中运行bash或任何命令。
http://t.cn/EwCEbxU

编辑:至尊宝
归档:https://elasticsearch.cn/article/3699
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

社区日报 第437期 (2018-11-03)

1、父子结构的排序方法
     http://t.cn/EwiSWFC
2、一款对聚合结果利用线性回归实时预测的插件
     http://t.cn/EwiXJ9g
3、一周热点:如果我在那辆重庆公交上
     http://t.cn/Ewitdiv
 
编辑: bsll
归档:https://elasticsearch.cn/article/3698
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1、父子结构的排序方法
     http://t.cn/EwiSWFC
2、一款对聚合结果利用线性回归实时预测的插件
     http://t.cn/EwiXJ9g
3、一周热点:如果我在那辆重庆公交上
     http://t.cn/Ewitdiv
 
编辑: bsll
归档:https://elasticsearch.cn/article/3698
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

访谈:Elastic 在今日头条广告系统中的大规模应用

欢迎来到 Elastic 社区电台的第七期节目,我们本期节目的嘉宾是来自于今日头条广告系统的工程师徐磊和张海雷,今日头条作为业界非常流行的新闻资讯类软件,坐拥上亿互联网用户,其内部目前正大量使用了 Elasticsearch 来解决各式各样的业务问题,最早从15年开始的接触,到如今多达几十个集群的规模,以及成为公司平台化的基础服务,承载着PB级规模的数据,快来收听本期节目来一探究竟吧。

嘉宾

  • 张海雷,今日头条广告系统研发工程师,现负责ES平台的运维以及平台化建设。
  • 徐磊,今日头条广告系统研发工程师,有3年大规模ELK集群运维及平台化经验。

podcast_toutiao_banner720x420.jpg

主持人

Elastic 技术布道师,曾勇(Medcl)。

收听

可以点击下面的任意链接来收听(时长约 34 分钟):

关于今日头条

北京字节跳动科技有限公司成立于2012年3月,公司的主要产品“今日头条”客户端,是一款基于数据挖掘技术的个性化推荐引擎产品。“今日头条”致力于帮助用户在移动互联网上方便快捷地获取最有价值的信息,它会根据用户的兴趣为其推荐内容,这是对传统信息分发方式的一次巨大颠覆

“今日头条”面市后,迅速获得市场认可,长期占据苹果应用商店新闻类榜首。目前已有超过160万个个人、组织开设头条号。

关于 Elastic 社区电台

Elastic 开源社区举办的一款播客类节目, 邀请来自开源社区的用户,一起聊聊 Elastic 开源产品的使用案例、经验分享、架构变迁等等。

继续阅读 »

欢迎来到 Elastic 社区电台的第七期节目,我们本期节目的嘉宾是来自于今日头条广告系统的工程师徐磊和张海雷,今日头条作为业界非常流行的新闻资讯类软件,坐拥上亿互联网用户,其内部目前正大量使用了 Elasticsearch 来解决各式各样的业务问题,最早从15年开始的接触,到如今多达几十个集群的规模,以及成为公司平台化的基础服务,承载着PB级规模的数据,快来收听本期节目来一探究竟吧。

嘉宾

  • 张海雷,今日头条广告系统研发工程师,现负责ES平台的运维以及平台化建设。
  • 徐磊,今日头条广告系统研发工程师,有3年大规模ELK集群运维及平台化经验。

podcast_toutiao_banner720x420.jpg

主持人

Elastic 技术布道师,曾勇(Medcl)。

收听

可以点击下面的任意链接来收听(时长约 34 分钟):

关于今日头条

北京字节跳动科技有限公司成立于2012年3月,公司的主要产品“今日头条”客户端,是一款基于数据挖掘技术的个性化推荐引擎产品。“今日头条”致力于帮助用户在移动互联网上方便快捷地获取最有价值的信息,它会根据用户的兴趣为其推荐内容,这是对传统信息分发方式的一次巨大颠覆

“今日头条”面市后,迅速获得市场认可,长期占据苹果应用商店新闻类榜首。目前已有超过160万个个人、组织开设头条号。

关于 Elastic 社区电台

Elastic 开源社区举办的一款播客类节目, 邀请来自开源社区的用户,一起聊聊 Elastic 开源产品的使用案例、经验分享、架构变迁等等。

收起阅读 »

社区日报 第436期 (2018-11-02)

1.Elasticsearch搜索词组,如何更准?
http://t.cn/EZFBj2R
2.Lucene倒排索引简述 之倒排表
http://t.cn/Ew5bwiE
3.Elasticsearch下分布式存储的数据分布
http://t.cn/Ew5bU5G

编辑:铭毅天下
归档:https://elasticsearch.cn/article/3682
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1.Elasticsearch搜索词组,如何更准?
http://t.cn/EZFBj2R
2.Lucene倒排索引简述 之倒排表
http://t.cn/Ew5bwiE
3.Elasticsearch下分布式存储的数据分布
http://t.cn/Ew5bU5G

编辑:铭毅天下
归档:https://elasticsearch.cn/article/3682
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

社区日报 第435期 (2018-11-01)

1.Elasticsearch的Query Cache梳理
http://t.cn/EwtwDxL
从Elastic APM发送数据到Logstash或Kafka
http://t.cn/EwtAzg3
使用Elasticsearch增强Wordpress搜索功能
http://t.cn/EwtAyhK

编辑:金桥
归档:https://elasticsearch.cn/article/3681
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1.Elasticsearch的Query Cache梳理
http://t.cn/EwtwDxL
从Elastic APM发送数据到Logstash或Kafka
http://t.cn/EwtAzg3
使用Elasticsearch增强Wordpress搜索功能
http://t.cn/EwtAyhK

编辑:金桥
归档:https://elasticsearch.cn/article/3681
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

社区日报 第434期 (2018-10-31)

1. 日志采集中的关键技术分析
http://t.cn/Ew2Wibs
2. 日志汇集系统搭建
http://t.cn/RDg9wU2
3. Elasticsearch通过reroute api重新分配分片
http://t.cn/Ew2lS08
 
编辑:江水
归档:https://elasticsearch.cn/article/3680
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1. 日志采集中的关键技术分析
http://t.cn/Ew2Wibs
2. 日志汇集系统搭建
http://t.cn/RDg9wU2
3. Elasticsearch通过reroute api重新分配分片
http://t.cn/Ew2lS08
 
编辑:江水
归档:https://elasticsearch.cn/article/3680
订阅:https://tinyletter.com/elastic-daily 收起阅读 »

社区日报 第433期 (2018-10-30)

1、Elasticsearch官方Node.js客户端。
http://t.cn/EwvuIHq
2、Elasticsearch文档和映射。
http://t.cn/EwvkYbt
3、Elasticsearch快速指南。
http://t.cn/Ewvk8JY

编辑:叮咚光军
归档:https://elasticsearch.cn/article/1021
订阅:https://tinyletter.com/elastic-daily
继续阅读 »
1、Elasticsearch官方Node.js客户端。
http://t.cn/EwvuIHq
2、Elasticsearch文档和映射。
http://t.cn/EwvkYbt
3、Elasticsearch快速指南。
http://t.cn/Ewvk8JY

编辑:叮咚光军
归档:https://elasticsearch.cn/article/1021
订阅:https://tinyletter.com/elastic-daily 收起阅读 »