Elasticsearch 的用户名和密码设置
itomcoil 2025-07-21 14:47 2 浏览
在 Elasticsearch 中,用户名和密码的设置取决于安装方式和版本。以下是详细说明:
1. Elasticsearch < 7.x 版本
- 默认无安全认证
早期版本默认不启用安全功能,无需用户名密码即可访问(bash):
curl http://localhost:9200
2. Elasticsearch >= 7.x & < 8.x 版本
- 安全功能默认禁用
需手动启用:
# 在 elasticsearch.yml 中启用
xpack.security.enabled: true
- 初始化密码
启用后运行设置密码命令(bash):
bin/elasticsearch-setup-passwords auto # 自动生成随机密码
或
bin/elasticsearch-setup-passwords interactive # 手动设置
默认用户:elastic、kibana、logstash_system 等
3. Elasticsearch >= 8.0 版本
安全功能默认开启
首次启动时:
- 自动生成 CA 证书
- 为内置用户生成随机密码
- 在终端输出密码信息(务必保存!),如:
Elasticsearch security features have been automatically configured!
Authentication is enabled and cluster connections are encrypted.
i Password for the elastic user (reset with `bin/elasticsearch-reset-password -u elastic`):
YOUR_RANDOM_PASSWORD_HERE # ← 这是 elastic 用户的密码
关键内置用户
用户名 | 权限 | 用途 |
elastic | 超级用户 (superuser) | 管理集群、所有索引 |
kibana_system | kibana 系统用户 | Kibana 连接 Elasticsearch |
logstash_system | logstash 系统用户 | Logstash 写入数据 |
beats_system | beats 系统用户 | Filebeat/Metricbeat 等 |
密码管理操作
- 重置 elastic 用户密码(bash):
bin/elasticsearch-reset-password -u elastic
- 创建新用户(bash):
Java 客户端连接示例(带认证)
- 通过 API 修改密码(bash):
curl -X POST "localhost:9200/_security/user/elastic/_password?pretty" \
-H "Content-Type: application/json" \
-u elastic:<current_password> \
-d '{"password": "<new_password>"}'
Java 客户端连接示例(带认证)
// 包含凭证的客户端初始化
RestClient restClient = RestClient.builder(
new HttpHost("localhost", 9200, "https")) // 8.x 默认用 HTTPS
.setHttpClientConfigCallback(httpClientBuilder -> {
// 1. 设置凭证
CredentialsProvider creds = new BasicCredentialsProvider();
creds.setCredentials(AuthScope.ANY,
new UsernamePasswordCredentials("elastic", "YOUR_PASSWORD"));
// 2. 信任自签名证书(开发环境)
SSLContext sslContext = SSLContextBuilder.create()
.loadTrustMaterial((chain, authType) -> true) // 信任所有证书
.build();
return httpClientBuilder
.setDefaultCredentialsProvider(creds)
.setSSLContext(sslContext);
})
.build();
// 创建 Transport 和 Client
ElasticsearchTransport transport = new RestClientTransport(restClient, new JacksonJsonpMapper());
ElasticsearchClient client = new ElasticsearchClient(transport);
生产环境安全建议
- 立即修改默认密码
首次启动后重置 elastic 用户的密码。 - 最小权限原则
为应用创建专属用户(非 elastic),例如(bash):
bin/elasticsearch-users roles add app_user -i logs-*
bin/elasticsearch-users useradd app_client -p client_pass -r app_user
- 启用 HTTPS
8.x 默认开启,7.x 需配置 xpack.security.http.ssl.enabled: true。 - 定期轮换密码
使用密钥管理服务(如 Vault)自动化密码更新。 - 审计日志
启用安全事件审计(yaml):
xpack.security.audit.enabled: true
注意:以上操作假设 Elasticsearch 已正确安装。如果使用 Docker/Kubernetes,密码可能通过环境变量设置(如 ELASTIC_PASSWORD)。
好了,爱学习的小伙伴,更多精彩,关注不迷路哟~
相关推荐
- Ollama使用指南【超全版】(olal la)
-
一、Ollama快速入门Ollama是一个用于在本地运行大型语言模型的工具,下面将介绍如何在不同操作系统上安装和使用Ollama。官网:https://ollama.comGithub:http...
- 电脑怎么优化(电脑怎么优化性能)
-
电脑配置和宽带流量也是硬件,但这些要求其实并不需要很高,关键还是怎么去安全使用电脑并进行有效的优化。电脑的应用和优化处理一、电脑的应用和优化处理二、目前,大家使用的个人电脑,配置方面均没多大问题,比如...
- 电脑win7中那些使用最频繁的命令原来这么丝滑,太顺手了
-
windows7是目前为止办公家用使用占比较大的操作系统,它的很多操作和整洁的界面让人不想替换,况且,对计算机硬件的支持也是很完美的!虽然目前主流的牛夫人win10和小甜甜win11已经占据了很大一边...
- .NetCore 设置环境变量(.net core环境搭建)
-
.NetCore设置环境变量开发过程中经常要发布一个版本到测试服上给测试人员测试,可能需要直接输出错误信息,需要设置环境变量为Development,如果是IIS可以设置web.config环境变量...
- 「分享」非常全面的CentOS7系统安全检测和加固脚本
-
CentOS7系统检测和加固脚本脚本来源:https://github.com/xiaoyunjie/Shell_Script主要是为了Linux系统的安全,通过脚本对Linux系统进行一键检测和一键...
- 手把手带你进行Golang环境配置(golang运行时配置文件目录)
-
前言大家好,我是星期八,是一个每天都要在镜子前给自己梳仅剩三根头发的三年码农本次我们来安排一下如何在win平台上配置Go语言开发环境。整体来说,Go配置环境还是挺轻松的,和Python差不多,并且会自...
- Elasticsearch 的用户名和密码设置
-
在Elasticsearch中,用户名和密码的设置取决于安装方式和版本。以下是详细说明:1.Elasticsearch<7.x版本默认无安全认证早期版本默认不启用安全功能,无需用户名...
- gpeditmsc找不到文件的解决方法亲测有效
-
Gpedit.msc找不到文件的怎么办?Gpedit.msc是用于打开Windows系统组策略的命令程序,缺少它系统会弹出“Gpedit.msc找不到”、“Gpedit.msc打不开”等提示,那么...
- Win7命令提示符输入taskkill提示不是内部或外部命令
-
使用win7系统的用户,想在命令提示符下使用taskkill命令删掉进程的时候,却提示taskkill不是内部或外部命令,也不是可运行的程序,遇到这样的问题,这位用户不知道怎么解决。所以给大家带来了解...
- 如何使用VSCode+gdbserver远程调试ZMC900E
-
由于嵌入式设备资源受限,通常无法在其上安装庞大的IDE调试程序,且许多嵌入式系统并无桌面环境。为了方便调试自开发程序,本文介绍利用VSCode与gdbserver进行嵌入式设备上程序的远程调试方法。...
- 系统优化 命令行也可以这么6?(进行系统优化)
-
由于命令行的简洁、高效,平时很多操作我们都爱使用命令行来完成。不过系统自带的命令行使用起来有各种不方便,如很多命令自带Y/N开关,这些命令需要手动输入Y/N才能完成,如果自行安装的命令行则要进入安装目...
- 不借助Linux系统,在Windows下如何搭建ZMC900E交叉编译环境
-
不需要依赖笨重的虚拟机,也不需要安装双系统。抛开繁琐的环境准备,在Windows上轻松搭建交叉编译环境。本文将介绍如何在Windows上搭建交叉编译环境,不借助Linux系统,直接进行交叉编译。前言...
- 超详细的rabbitmqctl管理和监控RabbitMQ命令总结
-
概述MQ全称为MessageQueue,消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序...
- 《Windows 学习:100 条命令大全》内容总结
-
一、文件与目录管理1.基础操作dir:用于列出当前目录下的文件和子目录。在命令提示符中输入dir,即可显示当前目录的内容,如文件名称、大小、修改日期等信息。若想查看隐藏文件,可使用dir/a命令。...
- Python 3.14 新特性盘点,更新了些什么?
-
Python3.14.0稳定版将于2025年10月正式发布,目前已进入beta测试阶段。这意味着在往后的几个月里,3.14的新功能已冻结,不再合入新功能(除了修复问题和完善文档)。3...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)