Elasticsearch--配置说明

作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO

联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬

学习必须往深处挖,挖的越深,基础越扎实!

阶段1、深入多线程

阶段2、深入多线程设计模式

阶段3、深入juc源码解析


阶段4、深入jdk其余源码解析


阶段5、深入jvm源码解析

码哥源码部分

码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】

码哥讲源码【炸雷啦!炸雷啦!黄光头他终于跑路啦!】

码哥讲源码-【jvm课程前置知识及c/c++调试环境搭建】

​​​​​​码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】

码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】

码哥讲源码【你水不是你的错,但是你胡说八道就是你不对了!】

码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】

终结B站没人能讲清楚红黑树的历史,不服等你来踢馆!

打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】

配置

Elasticsearch配置文件在elasticsearch/config文件夹下。在这个文件夹中有两个文件,一个是Elasticsearch配置不同模块的配置文件elasticsearch.yml,另一个是Elasticsearch日志的配置文件logging.yml。默认配置文件为YML。

Elasticsearch提供了多种方式进行设置,在系统内部,都使用命名空间来表示这些设置,根据这些命名空间,系统可以很容易地扩展到其他格式。

比如设置节点名称如下:

  • yml格式:node.name:node-1
  • JSON格式:只需要把elasticsearch.yml名修改成elasticsearch.json。

配置方式为:

    {
    	"node":{"name":"node-1"}
    }

通过Elasticsearch命令的参数来设置配置信息。

    elasticsearch -Des.node.name=node-1

Elasticsearch还可以通过交互式方式进行设置,通过${prompt.text}或者${prompt.secret}来指定,${prompt.secret}表示在终端中隐藏输入的值,${prompt.text}表示在终端中显示输入的值:

    node.name:${prompt.text}
    //在Elasticsearch命令执行时,将提示你输入的实际值,如下
    Enter value for [node.name]:

注意:当Elasticsearch所谓服务或者在后台启动的时候,这两个参数不起作用。

elasticsearch.yml配置说明

1. 集群名称:
cluster.name: my-application
确保在不同的环境中集群的名称不重复,否则,节点可能会连接到错误的集群上。

2. 节点名称:
node.name: node-1
默认情况下,当节点启动时ELasticsearch将随机在一份3000个名字的列表中随机指定一个。如果机器上只运行一个集群Elasticsearch节点,可以用${HOSTNAME}设置节点的名称为主机名。

3. 节点描述:
node.rack: r1

4. 索引存储位置:
path.data: /path/to/data

5. 日志存储位置:
path.logs: /path/to/logs

6. 内存分配模式:
bootstrap.mlockall: true

7. 绑定的网卡IP:
network.host: 192.168.0.1

8. http协议端口:
http.port: 9200

9. 开始发现新节点的IP地址:
discovery.zen.ping.unicast.hosts: ["host1", "host2"]

10. 最多发现主节点的个数:
discovery.zen.minimum_master_nodes: 3

11. 当重启集群节点后最少启动N个节点后开始做恢复:
gateway.recover_after_nodes: 3

12. 在一台机器上最多启动的节点数:
node.max_local_storage_nodes: 1

13. 当删除一个索引的时候,需要指定具体索引的名称:
action.destructive_requires_name: true

索引配置说明

在集群中创建的索引可以提供每个索引自己的设置。

例如:下面创建一个索引刷新间隔是5秒而不是默认的刷新间隔(格式可以shiYAML或JSON):

请求:PUT http://127.0.0.1:9200/kimchy
参数:index:refresh_interval: 5s

这个索引参数可以设置在节点上,例如,在elasticsearch.yml文件中可以设置:
index.refresh_interval: 5s

这意味着除非索引明确定义,这个节点上创建的每个索引的刷新间隔为5s

也可以在启动Elasticsearch的时候用参数指定:
elasticsearch -Des.index.refresh_interval=5s

日志配置说明

Elasticsearch内部使用log4j记录系统日志,它试图通过使用YAML配置方式来简化log4j的配置,配置文件位置为elasticsearch/config/logging.yml。

JSON格式和键值对的格式也是支持的。可以加载多个配置文件,在启动Elasticsearch后系统自动合并多个配置文件。支持不同的后缀格式,例如:(.yml, .yaml. .json or .properties)。

记录器部分包含java包和相应的日志级别,在匹配里可以省略org.elasticsearch前缀。Appdnder部分包含日志描述信息。

  • 10
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值