elasticsearch.yml详解,基于ES V5.5.1

elasticsearch.yml是yaml格式的elasticsearch配置文件,列出来了针对生产环境下的一些重要配置。其默认路径为:$ES_HOME/config/。

我们知道elasticsearch已经为我们提供了很多合理的默认值。但是全面的了解一下配置文件中的配置项,对于理解elasticsearch是很有帮助的。

首先我们要对yaml格式的文件有一个基本概念:

  1. 属性顶格写,不能有空格
  2. 索引一定不能使用tab制表符
  3. 属性和值之间的":"后边要有空格
  4. 例如: network.host: 192.168.0.1
# ======================== Elasticsearch Configuration =========================
# ======================== Elasticsearch 配         置 =========================
#
# NOTE: Elasticsearch comes with reasonable defaults for most settings.
#       Before you set out to tweak and tune the configuration, make sure you
#       understand what are you trying to accomplish and the consequences.
# 注意:Elasticsearch为大多数配置项提供了合理的默认值。
#       在开始调整配置前,请确保你了解要完成的任务和后果。
#
# The primary way of configuring a node is via this file. This template lists
# the most important settings you may want to configure for a production cluster.
# 配置节点的主要方式是通过本文件。
# 以下的模板列出了你最有可能要为生产集群配置的配置项。
#
# Please consult the documentation for further information on configuration options:
# 请参阅文档获取更多有关配置项的信息。
# https://www.elastic.co/guide/en/elasticsearch/reference/index.html
#
# ---------------------------------- Cluster -----------------------------------
#
# Use a descriptive name for your cluster:
# 为你的集群设置描述性的名称:
# 
# 默认值:elasticsearch
#
# 拥有相同cluster.name的节点可以加入同一集群。注意不要在不同环境中设置相同的cluster.name,以防节点加错集群
#
#cluster.name: my-application
#
# ------------------------------------ Node ------------------------------------
#
# Use a descriptive name for the node:
# 为你的节点设置描述性的名称:
# 
# 默认值:随机生成的uuid的前7个字符
# 
# 注意:同一集群的节点名称不能重复。
#
# 注意:官方文档中提到,node.name是持久的,并且在节点重新启动时不会更改,因此默认节点名称也不会更改。
# 然而当你在修改了已经启动过的节点的node.name时,es会因找不到原节点名下的shards而报警告,但是在新的节点名下还是可以找到shards和indices。
# 
# node.name 可以被设置为当前服务器的HOSTNAME:
#
#node.name: ${HOSTNAME}
#
#node.name: node-1
#
# Add custom attributes to the node:
# 向节点添加自定义属性:
#
# 为节点配置其在物理机中所在的机架(用于shard allocation awareness)
#
#node.attr.rack: r1
#
#
#
# -----关于node再说几句:-----
#
# 默认情况下,集群中的每个节点都可以处理HTTP和Transport。 
# Transport层只用于节点和Java TransportClient之间的通信; 
# HTTP层仅由外部REST客户端使用。
#
# 所有节点都知道集群中的所有其他节点,并将客户端请求转发到适当的节点。
#
# 除此之外,每个节点都有一个或多个目的:
#
# *Master-eligible node:
# 一个节点的node.master设置为true(默认),这使得它有资格被选为主节点,控制集群。
# 
#node.master: true
#
# *Data node:
# node.data设置为true(默认)的节点。
# 数据节点是否保存数据并执行数据相关操作,如: CRUD,搜索和聚合。
#
#node.data: true
#
# *Ingest node:
# node.ingest设置为true(默认)的节点。
# 获取节点能够将 [ingest pipeline]应用于文档,以便在索引之前变换和丰富文档。
# 使用沉重的请求负载,使用专门的请求节点并将主节点和数据节点标记为node.ingest:false是有意义的。
#
#node.ingest: true
#
# ----------------------------------- Paths ------------------------------------
#
# Path to directory where to store the data (separate multiple locations by comma):
# 存储数据的目录路径(用',"分割表示多个位置):
#
#path.data: /path/to/data
#
# Path to log files:
# 存储日志文件的路径:
#
#path.logs: /path/to/logs
#
# 以上两个配置非常重要。elasticsearch建议将文件与程序分离,这样之后的维护、迁移、升级都会非常方便。程序崩溃也不会影响数据。
# 默认配置为ES主目录下创建。
#
#
# ----------------------------------- Memory -----------------------------------
#
# Lock the memory on startup:
# 启动时锁定内存:
#
#bootstrap.memory_lock: true
#
# Make sure that the heap size is set to about half the memory available
# on the system and that the owner of the process is allowed to use this
# limit.
# 确保堆设置为系统可用内存大小的大约一半,
# 并且允许进程所有者使用此限制。
#
# Elasticsearch performs poorly when the system is swapping the memory.
# 当系统内存交换时,elasticsearch表现不佳。
#
# ---------------------------------- Network -----------------------------------
#
# Set the bind address to a specific IP (IPv4 or IPv6):
# 将绑定的地址设置为特定IP(IPv4或IPv6):
#
# 默认为_local_(127.0.0.1)。
# 当此项不为_local_时,es认为从开发模式转移到生产模式。
# 
# 可用特殊值:
# _[networkInterface]_,例如,网络接口的地址_en0_。
# _local_,例如,系统上的任何回送地址127.0.0.1
# _site_,例如,系统上的任何站点本地地址192.168.0.1。
# _global_,例如,系统上的任何全局作用域地址8.8.8.8。
#
# 这些特殊值默认在IPv4和IPv6都可工作,但是你可以用":ipv4"、":ipv6"这两个限定说明符来指定。
# 例如, _en0:ipv4_只会绑定到接口的IPv4地址en0。
# 
#network.host: 192.168.0.1
#
# Set a custom port for HTTP:
# 自定义配置HTTP端口:
# 接受单个值或范围。如果指定了范围,则节点将绑定到范围中的第一个可用端口。
# 默认为9200-9300
#
#http.port: 9200
#
# 自定义tcp端口:
# 接受单个值或范围。如果指定了范围,则节点将绑定到范围中的第一个可用端口。
# 默认为9300-9400
#
#transport.tcp.port: 9300
#
# For more information, consult the network module documentation.
# 有关更多信息,请查阅网络模块文档。
# --------------------------------- Discovery ----------------------------------
#
# 这部分主要设置集群节点间的链接,所以叫做Discovery
#
# Pass an initial list of hosts to perform discovery when new node is started:
# The default list of hosts is ["127.0.0.1", "[::1]"]
# 在新节点启动时,遍历一个内置的host列表来进行发现:
# 默认的host列表是["127.0.0.1", "[::1]"]
#
# 127.0.0.1,表示ipv4的回环地址;[::1],表示ipv6的回环地址。
#
# 注意,这里使用的端口是tcp端口。
# 注意,当不设置port时,将使用默认的transport.profiles.default.port值,如果此值也为设置则使用transport.tcp.port
# 主机名将被尝试解析成能解析的多个IP
# 
#discovery.zen.ping.unicast.hosts: ["host1", "host2"]
#
# Prevent the "split brain" by configuring the majority of nodes (total number of master-eligible nodes / 2 + 1):
# 通过设置大部分节点来避免脑裂(master候选节点的总数 / 2 + 1):
# 例如,你有三个master候选节点,最小的主节点数应被设置为(3/2)+1或者是2
#
#discovery.zen.minimum_master_nodes: 3
#
#
# For more information, consult the zen discovery module documentation.
# 更多有关信息,请参阅zen发现模块文档。
#
# ---------------------------------- Gateway -----------------------------------
#
# Block initial recovery after a full cluster restart until N nodes are started:
# 整个集群重启后,在N个节点启动前,阻碍数据恢复处理:
# 默认是1
#
#gateway.recover_after_nodes: 3
#
# For more information, consult the gateway module documentation.
# 有关更多信息,请参阅网关模块文档。
#
# ---------------------------------- Various -----------------------------------
#
# Require explicit names when deleting indices:
# 在删除索引时是否需要明确索引名:
# 换句话说,是否可以通过正则或者_all删除或者关闭索引,默认true表示必须需要显式指定索引名称
# 生产环境建议设置为true,删除索引的时候必须显式指定,否则可能会误删索引库中的索引。
# 
#action.destructive_requires_name: true

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,451评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,172评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,782评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,709评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,733评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,578评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,320评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,241评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,686评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,878评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,992评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,715评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,336评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,912评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,040评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,173评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,947评论 2 355

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,657评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,815评论 6 342
  • 文章名称:Elasticsearch Reference[2.2]原文地址:https://www.elastic...
    code4j阅读 645评论 0 1
  • Elastic+logstash+head简单介绍 一. 概述 ElasticSearch是一个基于Lucene的...
    柒月失凄阅读 4,269评论 0 4
  • 失业了,忙着找工作呢!昨天来电话通知我过去面试,于是今天做好准备出发了。 从番禺到海珠下车,导航开始。 发现到终点...
    现进阅读 304评论 1 0