Dockerizing Elasticsearch 入门教程

概述

Elasticsearch 是一种分布式的、开源的搜索和分析引擎。在前端开发中,我们经常需要用到 Elasticsearch 来管理和检索数据。

Docker 是一种容器化平台,它可以轻松地在任何地方部署应用程序。使用 Docker 可以方便地创建和共享镜像,这使得 Elasticsearch 的部署变得更加简便。

本篇文章将介绍如何使用 Docker 快速容器化 Elasticsearch,并提供详细的步骤及示例代码,帮助您快速上手。

环境需求

在开始之前,请确保您已经安装了以下软件:

  • Docker
  • Docker Compose

步骤

1. 创建 Dockerfile 文件

Dockerfile 文件是用于构建 Docker 镜像的脚本。在本例中,我们需要使用 Dockerfile 文件来创建 Elasticsearch 镜像。

对于 Elasticsearch 服务,我们需要安装 Java 和 Elasticsearch。

创建一个新的文件夹并在其中创建 Dockerfile 文件。

# 在基础镜像的基础上构建新镜像
FROM docker.elastic.co/elasticsearch/elasticsearch:7.9.3

# 修改 elasticsearch.yml 中的配置
RUN echo "cluster.name: my-cluster" >> /usr/share/elasticsearch/config/elasticsearch.yml
RUN echo "network.host: 0.0.0.0" >> /usr/share/elasticsearch/config/elasticsearch.yml
RUN echo "discovery.type: single-node" >> /usr/share/elasticsearch/config/elasticsearch.yml

在 Dockerfile 中,我们使用了 FROM 命令来获取 Elasticsearch 的镜像。然后,我们修改 Elasticsearch 的配置文件,设置了集群名称、主机地址和发现类型。

2. 构建 Docker 镜像

进入到 Dockerfile 所在的目录,并执行以下命令来构建镜像。

docker build -t elasticsearch .

其中,-t 参数用于为镜像设置一个名称,这里我们将名称设置为 elasticsearch

3. 启动容器

现在,我们已经成功构建了 Elasticsearch 的镜像,接下来就是启动容器了。

在启动之前,我们需要先创建一个 Docker Compose 文件。创建一个文件夹并在其中创建一个 docker-compose.yml 文件。

version: '3'
services:
  elasticsearch:
    image: elasticsearch
    ports:
      - "9200:9200"
      - "9300:9300"

在 Docker Compose 文件中,我们定义了一个服务(service),并使用了我们刚刚构建好的 elasticsearch 镜像。我们还在其中定义了两个端口(9200 和 9300),这些端口是 Elasticsearch 服务所需的端口。

接下来,在文件夹中执行以下命令启动容器:

docker-compose up

这个过程可能需要一点时间,因为 Docker 需要下载 Elasticsearch 镜像。

如果您希望容器在后台运行,可以使用以下命令:

docker-compose up -d

成果展示

现在,您已经成功启动了 Elasticsearch 的 Docker 容器。您可以使用浏览器访问以下 URL:

如果您看到了以下输出,那么说明 Elasticsearch 正常运行。

{
  "name" : "Laptop",
  "cluster_name" : "my-cluster",
  "cluster_uuid" : "-------------------",
  "version" : {
    "number" : "7.9.3",
    "build_flavor" : "default",
    "build_type" : "docker",
    "build_hash" : "panels-git-clone/f70ad58d6d66b25a7a9e2d4ff2b0f7072ccbdf7e/panels-core-2020-10-14T19:11:30Z",
    "build_date" : "2020-10-14T19:11:30.153693Z",
    "build_snapshot" : false,
    "lucene_version" : "8.6.2",
    "minimum_wire_compatibility_version" : "6.8.0",
    "minimum_index_compatibility_version" : "6.0.0-beta1"
  },
  "tagline" : "You Know, for Search"
}

总结

在本文中,我们介绍了如何使用 Docker 快速容器化 Elasticsearch,并提供了详细的步骤及示例代码。希望这篇文章能够帮助您更好地理解如何使用 Docker 容器化应用程序。

不仅如此,使用 Docker 做容器化是一个不错的选择,因为这不仅简化了应用程序的部署流程,而且还提供了更好的可伸缩性和安全性。我们希望这篇文章能够帮助您更好地理解如何使用 Docker 容器化 Elasticsearch,并为您的应用程序部署带来更多便利。

来源:JavaScript中文网 ,转载请注明来源 本文地址:https://www.javascriptcn.com/post/65a10ffaadd4f0e0ff935675


纠错反馈