# 配置

# 目录结构

  • bin脚本文件目录,包括:启动、停止 ES,按照插件。运行统计数据等
  • config配置文件目录,如集群配置文件,user,role based 相关配置
    • elasticsearch.yml:用于配置Elasticsearch运行参数
    • jvm.options:JVM 配置
    • log4j2.properties:用于配置Elasticsearch日志
  • data数据文件目录,如存放索引文件等
    • path.data
  • jdk:Java 运行环境
  • lib:Java 类库
  • logs:日志文件目录
  • modules:模块目录,包含所有 ES 的功能模块
  • plugins:插件目录,包含所有 ES 已按照插件

# elasticsearch.yml

配置格式是YAML,可以采用如下两种方式:

  • 方式1:层次方式path: data: /var/lib/elasticsearch logs: /var/log/elasticsearch
  • 方式2:属性方式path.data: /var/lib/elasticsearch path.logs: /var/log/elasticsearch

本项目采用方式2,例子如下:

#配置elasticsearch的集群名称,默认是elasticsearch。
cluster.name: xuecheng
#节点名,通常一台物理服务器就是一个节点,es会默认随机指定一个名字。一个或多个节点组成一个cluster集群,集群逻辑概念,节点物理概念
node.name: xc_node_1
#设置绑定主机的ip地址,设置为0.0.0.0表示绑定任何ip,允许外网访问,生产环境建议设置为具体的ip
network.host: 0.0.0.0
#设置对外服务的http端口,默认为9200
http.port: 9200
#集群结点之间通信端口
transport.tcp.port: 9300
#指定该节点是否有资格被选举成为master结点,默认是true,如果原来的master宕机会重新选举新的master
node.master: true
#指定该节点是否存储索引数据,默认为true
node.data: true
#设置集群中master节点的初始列表
discovery.zen.ping.unicast.hosts: ["0.0.0.0:9300", "0.0.0.0:9301"]
#主结点数量的最少值 ,此值的公式为:(master_eligible_nodes / 2) + 1 ,比如:有3个符合要求的主结点,那么这里要设置为2。
discovery.zen.minimum_master_nodes: 1
node.ingest: true
#设置为true可以锁住ES使用的内存,避免内存与swap分区交换数据
bootstrap.memory_lock: false
#单机允许的最大存储结点数,通常单机启动一个结点建议设置为1,开发环境如果单机启动多个节点可设置大于1
node.max_local_storage_nodes: 2

#设置索引数据的存储路径,默认是es根目录下的data文件夹,可设置多个,用逗号隔开
path.data: C:\Develop\Elasticsearch\elasticsearch-1\data
#设置日志文件的存储路径,默认是es根目录下的logs文件夹
path.logs: C:\Develop\Elasticsearch\elasticsearch-1\logs

#开启cors跨域访问支持,默认为false
http.cors.enabled: true
#跨域访问允许的域名地址,(允许所有域名)以下使用正则
http.cors.allow-origin: /.*/
  • path.conf:设置配置文件的存储路径tar或zip包安装在config文件夹,rpm安装默认在/etc/elasticsearch
  • path.plugins: 设置插件的存放路径,默认是es根目录下的plugins文件夹
  • discovery.zen.ping.timeout: 3s 设置ES自动发现节点连接超时的时间,默认为3秒,如果网络延迟高可设置大些

# jvm.options

7.1 下默认设置为 1GB。配置建议:

  • Xmx 和 Xms (即最小及最大的JVM堆内存)设置为一样
  • Xmx 不要超过机器内存的 50%
  • 不要超过 300GB,详见
-Xms2g
-Xmx2g

# log4j2.properties

日志文件设置,ES使用log4j2,注意日志级别的配置

# 系统配置

在linux上根据系统资源情况,可将每个进程最多允许打开的文件数设置大些。

su limit -n 查询当前文件数

使用命令设置limit:先切换到root,设置完成再切回elasticsearch用户

sudo su
ulimit ‐n 65536
su elasticsearch

也可通过下边的方式修改文件进行持久设置:

/etc/security/limits.conf,将下边的行加入此文件:

elasticsearch ‐ nofile 65536