linux elasticsearch-8.2.0安装

下载并解压缩,命令行前不要留空格

官方下载地址:https://www.php.cn/link/88a9225cf17ea3bf8bef2b4658ef7bf2

下载链接:https://www.php.cn/link/fc64088b0f734c47f016d7a69cc53333

linux elasticsearch-8.2.0安装

解压命令:tar -zxvf elasticsearch-8.2.0-linux-x86_64.tar.gz

切换到目录:cd /usr/local/elasticsearch-8.2.2/bin/

启动Elasticsearch:./elasticsearch

[root@VM-4-3-centos bin]# ./elasticsearch

创建es用户

[root@VM-4-3-centos ~]# useradd es

[root@VM-4-3-centos ~]# passwd es

[root@VM-4-3-centos ~]# id es

uid=1001(es) gid=1001(es) groups=1001(es)

如果使用root账号启动Elasticsearch会报错:java.lang.RuntimeException: can not run elasticsearch as root

使用root账号创建用户:sudo adduser es

设置密码:sudo passwd es

对es用户授权,目录elasticsearch-8.2.0(重要):sudo chown -R es:es elasticsearch-8.2.0

切换es账号并启动服务

su es

./bin/elasticsearch

后台运行,避免客户端退出后服务停止:./bin/elasticsearch -d

帮衣帮-AI服装设计 帮衣帮-AI服装设计

AI服装设计神器,AI生成印花、虚拟试衣、面料替换

帮衣帮-AI服装设计 106 查看详情 帮衣帮-AI服装设计

当看到“started”时,服务已成功启动

关闭ES服务:kill pid

说明:Elasticsearch使用9300和9200端口,其中9300为tcp通讯端口,用于集群节点间通信,9200为http协议的RESTful接口

启动时报错,调整配置文件属性

解决内存不足问题:启动时卡住,可能是由于Elasticsearch默认分配的JVM空间大小为2g。修改JVM空间大小,如果Linux服务器配置较高,可以不做修改。

修改JDK启动内存:vim /usr/local/elasticsearch-8.2.0/config/jvm.options

-Xms256m-Xmx256m

报错:Native controller process has stopped – no new native processes can be started

继续配置文件:sudo vim /etc/security/limits.conf

* soft nofile 262144* hard nofile 131072* soft nproc 4096* hard nproc 4096

报错信息:

bootstrap check failure [1] of [3]: max number of threads [2048] for user [es] is too low, increase to at least [4096]

bootstrap check failure [2] of [3]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

bootstrap check failure [3] of [3]: the default discovery settings are unsuitable for production use; at least one of [discovery.seed_hosts, discovery.seed_providers, cluster.initial_master_nodes] must be configured

soft nproc:单个用户可用的最大进程数量(超过会警告);hard nproc:单个用户可用的最大进程数量(超过会报错);soft nofile:可打开的文件描述符的最大数(超过会警告);hard nofile:可打开的文件描述符的最大数(超过会报错)

bootstrap check failure [1] of [1]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

在es bin目录执行:vim ../config/elasticsearch.yml

修改配置文件:

cluster.name: es.studynode.name: node-1network.host: 0.0.0.0http.port: 9200bootstrap.memory_lock: false#system_call_filter启动报错,去掉#bootstrap.system_call_filter: false# 为Elasticsearch设置登录密码xpack.security.enabled: falsecluster.initial_master_nodes: ["node-1"]# error downloading geoip database [GeoLite2-Country.mmdb]#关闭geoip数据库的更新ingest.geoip.downloader.enabled: false

其他

linux elasticsearch-8.2.0安装linux elasticsearch-8.2.0安装linux elasticsearch-8.2.0安装

以上就是linux elasticsearch-8.2.0安装的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/452487.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 23:59:03
下一篇 2025年11月8日 00:00:19

相关推荐

  • 如何在Linux环境中配置Golang开发工具

    安装Go并配置环境变量,设置模块代理与VS Code开发工具,创建项目验证运行调试功能。 在Linux系统中配置Golang开发环境并不复杂,只要按步骤设置好Go语言运行时、工作区和开发工具,就能快速开始编码。以下是详细的配置流程。 安装Go语言环境 从官方下载适合你系统的Go二进制包,推荐使用稳定…

    2025年12月16日
    000
  • Go语言中lib/pq驱动与PostgreSQL SQL占位符的正确使用指南

    在使用go语言的`lib/pq`驱动连接postgresql数据库时,sql查询中的参数占位符应采用postgresql特有的`$1`, `$2`等序号形式,而非常见的`?`问号形式。本文详细介绍了这一语法规范,并通过示例代码演示了如何正确地构建参数化查询,以避免语法错误,同时确保数据库操作的安全性…

    2025年12月16日
    000
  • Go语言中实现通用的XML到JSON转换函数

    本文详细阐述了在Go语言中构建一个通用函数,以实现不同数据结构类型之间的XML到JSON转换。通过利用Go的`interface{}`特性,并结合`encoding/xml`和`encoding/json`包,我们将展示如何优雅地处理类型参数,避免常见错误,并提供实用的代码示例和使用场景,以帮助开发…

    2025年12月16日
    000
  • 使用 Go 语言将字符串映射到 JSON 对象中的多种类型

    本文介绍了如何在 Go 语言中创建能够转换为 JSON 对象的 map,该 map 可以包含字符串到不同类型的映射,例如字符串到字符串、字符串到数字等。核心在于使用 `interface{}` 类型作为 map 的值类型,使其能够存储任意类型的数据,并利用 `encoding/json` 包进行 J…

    2025年12月16日
    000
  • Go Goroutine 上下文切换机制详解

    本文深入探讨 Go 语言中 goroutine 的调度机制,重点解析 goroutine 上下文切换的时机。目前,Go 尚未实现抢占式调度,上下文切换主要发生在 I/O 操作期间。我们将详细解释这一机制,并展望未来 Go 版本中抢占式调度的发展。 Go 语言的并发模型基于 goroutine,它是一…

    2025年12月16日
    000
  • 在 Go (Golang) 中枚举注册表值

    本文介绍了如何在 Go (Golang) 中枚举 Windows 注册表中的值。通过使用 `golang.org/x/sys/windows/registry` 包,我们可以安全有效地读取注册表键值,并将它们转换为字符串,以便在应用程序中使用。文章提供了详细的代码示例,展示了如何打开注册表键、读取键…

    2025年12月16日
    000
  • 在 Gorilla Mux 中创建带可选 URL 变量的路由

    本文详细介绍了如何在 Go 语言的 Gorilla Mux 路由库中实现带有可选 URL 变量的路由。核心策略是通过注册两个独立的路由来处理有变量和无变量的两种情况,并在相应的处理器函数中利用 `mux.Vars` 检查变量是否存在,从而灵活地响应不同的 URL 模式,确保应用程序能够优雅地处理动态…

    2025年12月16日
    000
  • Go 并发修改结构体切片:从切片语义到并发安全机制

    本文深入探讨了在 go 语言中并发修改结构体切片时遇到的两大核心问题:切片操作的语义行为(尤其是 `append` 导致的切片重分配)以及并发环境下的数据竞争。文章详细介绍了通过返回新切片、传递结构体指针来正确处理切片修改,并提供了使用 channel、内嵌 `sync.mutex` 或全局 `sy…

    2025年12月16日
    000
  • Go 协程调度机制详解:何时发生上下文切换?

    本文深入探讨 Go 语言的协程调度机制,重点解析协程上下文切换发生的时机。当前 Go 版本采用协作式调度,上下文切换主要发生在 I/O 操作期间,而非 CPU 密集型计算。文章将详细解释这一机制,并展望未来 Go 版本中可能引入的抢占式调度。 Go 协程调度机制 Go 语言的协程(goroutine…

    2025年12月16日
    000
  • Go语言条件编译:利用构建约束实现跨平台代码管理

    go语言通过构建约束(build constraints)提供了一种优雅的机制,允许开发者根据目标操作系统、架构、编译器或自定义标签,有条件地编译特定源文件。这对于处理平台特有依赖,如cgo与windows api的集成,或在不同系统上模拟功能,提供了强大的支持,确保代码在多种环境中高效且无缝地运行…

    2025年12月16日
    000
  • 获取Go语言切片底层数组的方法

    本文旨在阐明Go语言中切片与底层数组的关系,重点解释为何以及如何(虽然实际上并不能直接)从切片访问其底层数组。文章将通过示例代码和逻辑分析,帮助读者深入理解Go语言切片的本质特性,并避免在实际开发中产生误解。 Go语言的切片(slice)是一种动态数组,它提供了对底层数组片段的引用。理解切片与底层数…

    2025年12月16日
    000
  • Golang解析动态键名JSON数据

    本文旨在解决go语言中解析具有动态顶层键的json字符串的挑战。我们将介绍如何利用go的`map[string]struct`结构来优雅地处理这类数据,从而实现对嵌套固定字段(如`name`和`age`)的提取,并提供详细的代码示例和最佳实践,确保解析过程的健壮性和可读性。 在Go语言中处理JSON…

    2025年12月16日
    000
  • 使用Go语言将字符串映射到多种类型的JSON对象

    本文旨在讲解如何使用Go语言创建能够将字符串映射到多种类型的JSON对象。由于Go语言的强类型特性,直接创建 `map[string]string` 或 `map[string]int` 类型的映射无法满足需求。本文将介绍如何利用 `interface{}` 类型来实现动态类型的JSON对象构建,并…

    2025年12月16日
    000
  • 在 Go 中实现 JSON Marshaller 处理嵌入式结构体

    本文将介绍如何在 Go 语言中高效地将包含嵌入式结构体的结构体进行 JSON 编码,特别是当嵌入式结构体实现了 `Marshaler` 接口时。我们将通过示例代码演示如何手动控制 JSON 序列化的过程,以确保所有字段都能正确地被编码。 在 Go 语言中,使用 encoding/json 包可以方便…

    2025年12月16日
    000
  • Go 语言 Goroutine 的上下文切换机制详解

    本文深入探讨 Go 语言中 Goroutine 的上下文切换机制。当前版本的 Go 语言调度器并非抢占式,Goroutine 的切换主要发生在 I/O 操作期间,例如网络请求、文件读写以及内存访问(如果数据不在寄存器中)。 了解这些机制对于编写高效的并发 Go 程序至关重要。本文将详细介绍相关原理,…

    2025年12月16日
    000
  • Go语言JSON解码:处理数字字符串键到整数键映射的策略

    本文探讨了在go语言中处理json数据时,如何将以数字字符串作为键的json对象有效转换为以整数作为键的go `map`类型。由于json规范仅支持字符串键,go的`encoding/json`包无法直接解码为`map[int]type`。文章详细介绍了先解码为`map[string]type`,然…

    2025年12月16日
    000
  • Go语言指针操作:如何正确修改通过指针传递的字符串值

    本文深入探讨go语言中通过指针修改字符串值的两种常见操作:`*dest = src` 和 `dest = &src`。我们将详细解析这两种赋值方式的底层机制和作用域影响,阐明为何前者能成功修改原始字符串,而后者仅在函数局部生效,旨在帮助开发者避免常见的指针误用,掌握go语言中指针的正确使用姿…

    2025年12月16日
    000
  • 如何在Golang中实现HTTP请求限流

    使用golang.org/x/time/rate包中的rate.Limiter可基于令牌桶算法实现HTTP请求限流,支持全局限流或按客户端IP独立限流,结合中间件和定期清理机制保障服务稳定性。 在Golang中实现HTTP请求限流,主要是为了防止服务被过多请求压垮,保障系统稳定性。常用的方式是使用令…

    2025年12月16日
    000
  • Go语言中如何扩展或修改第三方包函数:替代方案与实践

    在go语言中,无法直接覆盖或重写已导入第三方包的函数。本文将探讨当需要修改或扩展现有包功能时,可采用的几种实用策略,包括代码分支(forking)、创建包装器函数以及重新评估依赖,以实现对外部库行为的定制化需求。 Go语言以其简洁、高效和强类型闻名,其包管理和编译机制也体现了这些设计哲学。与某些动态…

    2025年12月16日
    000
  • Golang 并发编程:安全地向共享切片追加元素

    本文深入探讨了在go语言中,多个goroutine并发地向同一个切片追加元素时可能遇到的竞态条件问题。文章提供了三种主要的并发安全解决方案:使用`sync.mutex`进行互斥访问、通过通道(channel)收集结果,以及在已知最终大小的情况下,通过预分配切片并按索引写入。通过详细的代码示例和解释,…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信