【es】解决es报错failed to authenticate user [elastic]

【es】解决es报错failed to authenticate user [elastic]

1.背景

某天使用接口查询es数据时出现报错,没有返回数据。想到是测试环境的es因为没内存又挂了,于是上服务器重启服务。

但是重启后等待一段时间再次查询es,还是同样报错,显示连接拒接。于是lsof -i:9200查看端口,端口没起来。

查看日志,显示
org.elasticsearch.action.UnavailableShardsException: at least one primary shard for the index [.security-7] is unavailable"

failed to authenticate user [elastic]

2.分析

索引.security-7因为没有分片成功,索引不可用,无法对elastic用户进行鉴权,进而导致服务不可用。

3.解决方案

  1. 新建用户,删除.security-7相关索引,重新设置elastic用户密码
  2. 新建用户,备份.security-7相关索引快照,恢复索引。

方案一简单快捷,但是会导致原来设置的鉴权用户信息丢失。方案二则最大程度恢复原来的环境。

因为是测试环境,于是采用方案一进行处理。

4.操作步骤

4.1 创建restore_user用户
bash 复制代码
./bin/elasticsearch-users useradd restore_user -p xxxxx -r superuser

这个命令用于创建一个名为restore_user的Elasticsearch用户。

-p xxxxx 指定了用户的密码,实际应用中需要将 xxxxx 替换为实际的密码。

-r superuser 指定了用户角色为超级用户,即具有系统的最高权限。

4.2 删除.security相关索引

bash 复制代码
curl -X DELETE "127.0.0.1:9200/.security-*" -u restore_user

通过curl命令发送HTTP请求,使用DELETE方法删除Elasticsearch中以.security-*开头的所有索引。

-u restore_user 表示使用之前创建的 restore_user 用户进行身份验证。

4.3重置用户密码
bash 复制代码
./bin/elasticsearch-setup-passwords interactive

这个命令用于交互式地设置Elasticsearch的密码。

执行后系统会提示你输入各个内置用户的密码,包括 elastic、apm_system、kibana 等,以确保这些账户的密码得到设置。

5.备注

方案二没有尝试,如果有成功操作了的勇士,请反馈一下效果给我,谢谢~

相关推荐
人大博士的交易之路32 分钟前
今日行情明日机会——20250606
大数据·数学建模·数据挖掘·数据分析·涨停回马枪
Leo.yuan3 小时前
数据库同步是什么意思?数据库架构有哪些?
大数据·数据库·oracle·数据分析·数据库架构
@泽栖4 小时前
ES数据聚合
elasticsearch·搜索引擎
keson要进步4 小时前
CICD实战(一) -----Jenkins的下载与安装
运维·ci/cd·centos·自动化·jenkins
SelectDB技术团队4 小时前
从 ClickHouse、Druid、Kylin 到 Doris:网易云音乐 PB 级实时分析平台降本增效
大数据·数据仓库·clickhouse·kylin·实时分析
Web极客码6 小时前
在WordPress上添加隐私政策页面
大数据·人工智能·wordpress
Apache Flink6 小时前
Flink在B站的大规模云原生实践
大数据·云原生·flink
itachi-uchiha7 小时前
Docker部署Hive大数据组件
大数据·hive·docker
viperrrrrrrrrr78 小时前
大数据学习(131)-Hive数据分析函数总结
大数据·hive·学习
張萠飛8 小时前
Linux下如何使用shell脚本导出elasticsearch中某一个index的数据为本地csv文件
linux·运维·elasticsearch