热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用Docker部署带有权限认证的Elasticsearch

本文介绍如何通过Docker容器化部署Elasticsearch,并集成一个免费的社区插件ReadonlyREST实现基本的权限认证功能。

选择 Elasticsearch 认证插件


为了实现 Elasticsearch 的基本权限管理,我们可以选择使用社区提供的免费插件 ReadonlyREST。该插件支持多种认证方式,包括基于用户名和密码的 HTTP 基本认证。


访问官网 https://readonlyrest.com/download/,根据您的需求选择合适的插件版本。通常需要提供使用的 Elasticsearch 版本和有效的电子邮件地址来获取下载链接。


创建 Dockerfile


本例中使用的是 Elasticsearch 6.8.0 版本。首先创建一个 Dockerfile 文件,用于定义构建自定义 Elasticsearch 镜像的过程:



FROM elasticsearch:6.8.0
COPY readonlyrest-1.18.0_es6.8.0.zip /plugins/readonlyrest-1.18.0_es6.8.0.zip
RUN sh -c 'echo -e "y" | /usr/share/elasticsearch/bin/elasticsearch-plugin install file:///plugins/readonlyrest-1.18.0_es6.8.0.zip'


构建 Docker 镜像


使用以下命令构建自定义的 Elasticsearch 镜像:



docker build -t elasticsearch:6.8.0 .


构建过程中可能遇到网络问题导致下载缓慢或失败,可以通过配置 Docker 使用国内镜像加速服务,如阿里云提供的 https://registry.docker-cn.com 或网易的 http://hub-mirror.c.163.com


配置 ReadonlyREST 插件


创建配置文件 readonlyrest.yml,设置基本的认证规则:



readonlyrest:
access_control_rules:
- name: "HTTP Basic Auth Required"
type: allow
auth_key: 用户名:密码


完成上述步骤后,即可启动 Elasticsearch 容器:



docker run -d --name elasticsearch -u 1000:1000 -v /d/data/elasticsearch6.8.0:/usr/share/elasticsearch/data -v /d/docker/elasticsearch6.8.0/readonlyrest.yml:/usr/share/elasticsearch/config/readonlyrest.yml -e "discovery.type=single-node" -e "xpack.security.enabled=false" -e "TZ=Asia/Shanghai" -p 9200:9200 elasticsearch:6.8.0


确保容器运行无误后,可通过浏览器访问 http://127.0.0.1:9200/ 并使用配置文件中设定的凭证登录,查看 Elasticsearch 的基本信息。


安装 Kibana 进行数据可视化


Kibana 是一个强大的数据分析与可视化平台,适用于 Elasticsearch 数据。通过以下命令安装 Kibana,并将其与之前部署的 Elasticsearch 实例关联起来:



docker run -d --name kibana -e ELASTICSEARCH_URL=http://192.168.1.8:9200 -e ELASTICSEARCH_USERNAME="您的用户名" -e ELASTICSEARCH_PASSWORD="您的密码" -p 5601:5601 kibana:6.8.0


请确保 Kibana 和 Elasticsearch 的版本相匹配,以避免兼容性问题。安装完成后,通过浏览器访问 http://127.0.0.1:5601 即可开始使用 Kibana 进行数据探索和分析。


推荐阅读
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • Windows 系统下 MySQL 8.0.11 的安装与配置
    本文详细介绍了在 Windows 操作系统中安装和配置 MySQL 8.0.11 的步骤,包括环境准备、安装过程以及后续配置,帮助用户顺利完成数据库的部署。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 离线环境下的Python及其第三方库安装指南
    在项目开发中,有时会遇到电脑只能连接内网或完全无法联网的情况。本文将详细介绍如何在这种环境下安装Python及其所需的第三方库,确保开发工作的顺利进行。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
author-avatar
梦露的殇_192
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有