Docker创建enrollment token错误异常

问题

部署完kibana,需要通过enrollment token方式来连接elasticsearch,此时需要在elasticsearch中创建enrollment token。

执行创建命令时,报如下错误:

bash 复制代码
elasticsearch-create-enrollment-token --scope kibana

ERROR: [xpack.security.enrollment.enabled] must be set to `true` to create an enrollment token, with exit code 78

原因解析及解决方案

创建enrollment token时,Elasticsearch 配置中的 [xpack.security.enrollment.enabled] 需要被设置为 true。这个设置是必须的,因为它启用了Elasticsearch的安全特性,允许通过enrollment token的方式来简化节点和Kibana实例的加入过程。

要解决这个问题,需要按照以下步骤操作:

修改Elasticsearch配置

首先,需要找到Elasticsearch的配置文件elasticsearch.yml。这个文件通常位于Elasticsearch安装目录下的config文件夹中。如果是通过Docker启动的Elasticsearch,需要先进入容器内部,或者在启动容器时通过挂载卷的方式来修改或替换这个配置文件。

设置xpack.security.enrollment.enabled为true

在elasticsearch.yml文件中,添加或修改以下行:

bash 复制代码
xpack.security.enrollment.enabled: true

这会启用安全特性,允许创建enrollment token。

重启Elasticsearch服务

修改配置后,需要重启Elasticsearch服务以使更改生效。如果是通过Docker运行的Elasticsearch,可以通过重启容器来实现:

bash 复制代码
docker restart elasticsearch

确保将elasticsearch替换为你的容器名称。

再次尝试创建enrollment token

在Elasticsearch服务重启并且配置更改生效后,再次尝试运行之前的命令:

bash 复制代码
docker exec -it elasticsearch bash
cd bin/
elasticsearch-create-enrollment-token --scope kibana

这次应该能够成功创建enrollment token,而不会遇到之前的错误。

请注意,启用Elasticsearch的安全特性(包括enrollment token机制)可能还需要你配置其他相关的安全设置,比如用户认证和加密通信等。确保你已经按照Elasticsearch的安全最佳实践来配置你的集群。

相关推荐
zhaotiannuo_19981 小时前
渗透测试之docker
运维·docker·容器
王正南2 小时前
kali-linux 虚拟机连接安卓模拟器
android·linux·运维·虚拟机连接模拟器·安卓模拟器,linux虚拟机
三不原则2 小时前
故障案例:容器启动失败排查(AI运维场景)——从日志分析到根因定位
运维·人工智能·kubernetes
吳所畏惧2 小时前
Linux环境/麒麟V10SP3下离线安装Redis、修改默认密码并设置Redis开机自启动
linux·运维·服务器·redis·中间件·架构·ssh
yueguangni2 小时前
sysstat 版本 10.1.5 是 CentOS 7 的默认版本,默认情况下确实不显示 %wait 字段。需要升级到新版sysstat
linux·运维·centos
funfan05173 小时前
【运维】MySQL数据库全量备份与恢复实战指南:从入门到精通
运维·数据库·mysql
-dcr3 小时前
49.python自动化
运维·python·自动化
萧曵 丶4 小时前
Linux 业务场景常用命令详解
linux·运维·服务器
乾元4 小时前
ISP 级别的异常洪泛检测与防护——大流量事件的 AI 自动识别与响应工程
运维·网络·人工智能·安全·web安全·架构
youxiao_905 小时前
kubernetes 概念与安装(一)
linux·运维·服务器