ElasticSearch之网络配置

news/2024/10/9 12:14:21/

对官方文档Networking的阅读笔记。
ES集群中的节点,支持处理两类通信平面

  • 集群内节点之间的通信,官方文档称之为transport layer。
  • 集群外的通信,处理客户端下发的请求,比如数据的CRUD,检索等,官方文档称之为HTTP layer。

对于这两个平面公共的配置,配置参数可以使用network.*
针对transport layer的配置参数,可以使用transport.*
针对HTTP layer的配置参数,可以使用http.*

参数networkhttptransportremote_cluster说明
hostnetwork.hosthttp.hosttransport.hostremote_cluster.host业务的监听地址。
bind_hostnetwork.bind_hosthttp.bind_hosttransport.bind_hostremote_cluster.bind_host默认值与host相同。
publish_hostnetwork.publish_hosthttp.publish_hosttransport.publish_hostremote_cluster.publish_host默认值与host相同。
publish_portN/Ahttp.publish_porttransport.publish_portremote_cluster.publish_port
portN/Ahttp.porttransport.portremote_cluster.port业务的监听端口。
tcp.keep_alivenetwork.tcp.keep_alivehttp.tcp.keep_alivetransport.tcp.keep_aliveremote_cluster.tcp.keep_aliveTCP socket的SO_KEEPALIVE参数,默认值为true。
tcp.keep_idlenetwork.tcp.keep_idlehttp.tcp.keep_idletransport.tcp.keep_idleremote_cluster.tcp.keep_idleTCP socket的TCP_KEEPIDLE参数,默认值为-1。
tcp.keep_intervalnetwork.tcp.keep_intervalhttp.tcp.keep_intervaltransport.tcp.keep_intervalremote_cluster.tcp.keep_intervalTCP socket的TCP_KEEPINTVL参数,默认值为-1。
tcp.keep_countnetwork.tcp.keep_counthttp.tcp.keep_counttransport.tcp.keep_countremote_cluster.tcp.keep_countTCP socket的TCP_KEEPCNT参数,默认值为-1。
tcp.no_delaynetwork.tcp.no_delayhttp.tcp.no_delaytransport.tcp.no_delayremote_cluster.tcp.no_delayTCP socket的TCP_NODELAY参数,默认值为true。详细说明见wiki。
tcp.reuse_addressnetwork.tcp.reuse_addresshttp.tcp.reuse_addresstransport.tcp.reuse_addressremote_cluster.tcp.reuse_addressTCP socket的SO_REUSEADDR参数,Windows平台的默认值为false,其它平台的默认值为true。
tcp.send_buffer_sizenetwork.tcp.send_buffer_sizehttp.tcp.send_buffer_sizetransport.tcp.send_buffer_sizeremote_cluster.tcp.send_buffer_sizeTCP的发送缓冲区的大小,默认值为-1,表示使用系统的默认值。
tcp.receive_buffer_sizenetwork.tcp.receive_buffer_sizehttp.tcp.receive_buffer_sizetransport.tcp.receive_buffer_sizeremote_cluster.tcp.receive_buffer_sizeTCP的接收缓冲区的大小,默认值为-1,表示使用系统的默认值。
compressionN/Ahttp.compressiontransport.compressionN/A压缩。

transport独有的参数:

  • transport.connect_timeout
  • transport.compress
  • transport.compression_scheme
    压缩算法,可选值包括deflate或者lz4,默认值为lz4。
  • transport.ping_schedule
    指示发送业务心跳的周期,默认值为-1,表示不发送业务心跳。

http独有的参数:

  • http.max_content_length
    HTTP请求消息体的长度的最大值,默认值为100MB。

  • http.max_initial_line_length
    HTTP请求中,URL的长度的最大值,默认值为4KB。

  • http.max_header_size
    HTTP请求中,HTTP头部的总长度的最大值,默认值为16KB。

  • http.compression
    使用HTTPS时,默认取值为false,其它情况下取值为true。

  • http.compression_level
    压缩级别,取值范围为[1, 9],默认值为3。

  • http.detailed_errors.enabled
    指定是否允许在HTTP响应消息中暴露详细的错误提示信息,默认值为true。

  • http.pipelining.max_events
    HTTP请求消息队列的长度,默认值为10000。

  • http.max_warning_header_count
    HTTP响应消息中允许包含的提示信息头部的数量,默认值为-1,即不限制。

  • http.max_warning_header_size
    HTTP响应消息中允许包含的提示信息头部的长度,默认值为-1,即不限制。

  • http.client_stats.enabled
    指示是否记录HTTP通信过程中的统计数据,默认值为true。

  • http.client_stats.closed_channels.max_count
    默认值为10000。

  • http.client_stats.closed_channels.max_age
    关闭HTTP通道之后,上传统计数据的时延值,默认值为5m。

http协议CORS特性相关的参数:

  • http.cors.enabled
    是否启用对CORS的支持。
  • http.cors.allow-origin
  • http.cors.max-age
    指示缓存HTTP方法OPTIONS的返回值的时长,即超时时间,默认值为1728000,即20天。
  • http.cors.allow-methods
    HTTP请求中允许使用的方法,默认值包括:
    • OPTIONS
    • HEAD
    • GET
    • POST
    • PUT
    • DELETE
  • http.cors.allow-headers
    允许在HTTP请求消息中使用的头部,默认值包括:
    • X-Requested-With
    • Content-Type
    • Content-Length
    • Authorization
    • Accept
    • User-Agent
    • X-Elastic-Client-Meta
  • http.cors.expose-headers
    指定在HTTP响应消息中返回的头部,默认值为X-elastic-product
  • http.cors.allow-credentials
    决定头部Access-Control-Allow-Credentials是否返回,默认值为false。

remote_cluster_server独有的参数:

  • remote_cluster_server.enabled
    指示是否启用远端集群,默认值为false。

网络通信的线程模型,这部分内容在处理通信相关的故障时非常意义,后续有空时详细阅读。
导出ES进程的栈时,使用关键字transport_worker来检索,可以看到相关的线程的栈。

参考资料

  • Nodes hot threads API

http://www.ppmy.cn/news/1536631.html

相关文章

C#使用Lazy<T>提高性能

以下是一些适合使用Lazy<T>的场景&#xff1a; 单例模式 在实现单例模式时&#xff0c;Lazy<T>是非常有用的。如前面提到的示例&#xff0c;它可以确保单例对象在首次被访问时才进行创建&#xff0c;同时在多线程环境下也能保证正确的行为。这种方式比传统的双重检…

Ubuntu22——安装并配置局域网文件共享系统Samba

我们将共享目录设置为 /home/takway/share。以下是基于这个新目录的详细步骤&#xff1a; 在Ubuntu上安装并配置Samba 更新系统包列表 打开终端&#xff0c;执行以下命令来确保你的包列表是最新的&#xff1a; sudo apt update安装Samba 安装Samba及其相关工具&#xff1a; sud…

mysql-索引笔记

索引 1、什么是索引 索引是对数据库中数据的一种结构化表示。它像一本书的目录&#xff0c;能够快速定位信息&#xff0c;而无需逐行扫描所有数据。 索引的出现其实就是为了提高数据查询的效率&#xff0c;就像书的目录一样。 2、索引的常见模型 2.1.哈希表 用一个哈希函…

计算机网络:物理层 —— 信道及其极限容量

文章目录 信道信道的极限容量信号失真失真类型产生信号失真的主要因素 奈式准则码元传输速率香农公式 信道 信道是指信息传输的通道或介质。在通信中&#xff0c;信道扮演着传输信息的媒介的角色&#xff0c;将发送方发送的信号传递给接收方。 信道可以是无线信道&#xff0c…

uniapp使用Vue3组合式,如何进行Vue模块自动导入

文章目录 uniapp使用Vue3组合式&#xff0c;如何进行Vue模块自动导入一、引言二、安装插件1、使用npm2、使用yarn3、使用pnpm4、安装特定版本 三、配置Vite插件四、去除手动导入五、总结 uniapp使用Vue3组合式&#xff0c;如何进行Vue模块自动导入 一、引言 在uniapp开发中&a…

java版基于Spring Boot + Mybatis在线招投标|评标|竞标|单一采购|询价|邀标|在线开标|招标公告发布|评审专家|招投标采购系统源码

一、项目说明 随着公司的快速发展&#xff0c;企业人员和经营规模不断壮大&#xff0c;公司对内部招采管理的提升提出了更高的要求。在企业里建立一个公平、公开、公正的采购环境&#xff0c;最大限度控制采购成本至关重要。符合国家电子招投标法律法规及相关规范&#xff0c;…

mybatisplus整合springboot3出错(springboot多模块开发)

1.mybatisplus版本太低或者maven导入没用如下的 <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-spring-boot3-starter</artifactId><version>3.5.5</version></dependency>2.maven导入冲突了&#xf…

进入xwindows后系统挂起(黑屏)键盘鼠标没有响应@FreeBSD

问题&#xff1a;黑屏能看见鼠标&#xff0c;键盘和鼠标没有反应 在不小心升级pkg包后&#xff0c;系统无法进入xfce等xwindows&#xff0c;表现为黑屏和能看见鼠标&#xff0c;左上角有一个白字符块&#xff0c;键盘鼠标没有反应&#xff0c;整个系统卡住。但是可以ssh登录&a…