使用Docker快速安装和运行Elasticsearch

Elasticsearch(简称ES)是一个支持海量数据的搜索引擎服务,广泛应用于大数据处理和实时分析。随着大数据时代的到来,掌握ES技术已成为进入大厂和获取高薪的关键技能之一。本文将详细介绍如何在Docker上安装和部署Elasticsearch,包括如何配置网络、运行容器、安装IK分词器等。

1. 创建网络

在部署Elasticsearch和Kibana之前,我们需要创建一个网络,以便这两个服务能够相互通信。在服务器上执行以下命令创建一个名为es-net的网络:

bash 复制代码
docker network create es-net

2. 拉取镜像

接下来,我们需要从Docker Hub拉取Elasticsearch和Kibana的镜像。这里我们使用的是7.17.18版本,因为它是一个稳定且较新的版本。在/usr/local目录下执行以下命令:

bash 复制代码
docker pull elasticsearch:7.17.18
docker pull kibana:7.17.18

3. 运行Elasticsearch容器

使用Docker命令运行Elasticsearch容器,并配置必要的环境变量和卷。以下是运行命令:

bash 复制代码
docker run -d \
  --name es \
  -e "ES_JAVA_OPTS=-Xms512m -Xmx512m" \
  -e "discovery.type=single-node" \
  -v es-data:/usr/local/elasticsearch7.17.18/data \
  -v es-plugins:/usr/local/elasticsearch7.17.18/plugins \
  -v es-logs:/usr/local/elasticsearch7.17.18/logs \
  --privileged \
  --network es-net \
  -p 9200:9200 \
  -p 9300:9300 \
  elasticsearch:7.17.18
bash 复制代码
docker run -d --name es -e "ES_JAVA_OPTS=-Xms512m -Xmx512m" -e "discovery.type=single-node" -v es-data:/usr/local/elasticsearch7.17.18/data -v es-plugins:/usr/local/elasticsearch7.17.18/plugins -v es-logs:/usr/local/elasticsearch7.17.18/logs --privileged --network es-net -p 9200:9200 -p 9300:9300 elasticsearch:7.17.18

4. 配置防火墙

为了能够从外部访问Elasticsearch,我们需要在服务器上配置防火墙规则,开放9200和9300端口:

bash 复制代码
firewall-cmd --zone=public --add-port=9200/tcp --permanent
firewall-cmd --zone=public --add-port=9300/tcp --permanent
firewall-cmd --reload

5. 验证安装结果

在浏览器中输入http://<你的云服务器公网IP地址>:9200/,如果看到Elasticsearch的欢迎信息,说明安装成功。

http://localhost:9200/

6. 部署Kibana

Kibana是Elasticsearch的可视化工具,可以帮助我们更方便地操作和管理Elasticsearch。在/usr/local目录下执行以下命令部署Kibana:

http://localhost:5601/app/home#/

bash 复制代码
docker run -d \
  --name kibana \
  -e ELASTICSEARCH_HOSTS=http://es:9200 \
  --network=es-net \
  -p 5601:5601 \
  kibana:7.17.18
bash 复制代码
docker run -d --name kibana -e ELASTICSEARCH_HOSTS=http://es:9200 --network=es-net -p 5601:5601 kibana:7.17.18

7. 安装IK分词器

IK分词器是Elasticsearch的中文分词插件,可以帮助我们更好地处理中文数据。首先,进入Elasticsearch容器:

bash 复制代码
docker exec -it es bash

然后,下载并安装IK分词器:

bash 复制代码
cd /usr/share/elasticsearch/bin
./elasticsearch-plugin install https://github.com/infinilabs/analysis-ik/releases/download/v7.17.18/elasticsearch-analysis-ik-7.17.18.zip

退出容器并重启Elasticsearch服务:

bash 复制代码
exit
docker restart es

8. 测试IK分词器

在Kibana的DevTools控制台中输入以下命令测试IK分词器:

json 复制代码
GET _analyze
{
  "analyzer": "ik_smart",
  "text": "测试IK分词器"
}

如果返回的结果正确,说明IK分词器已经成功安装并可以使用。

总结

通过上述步骤,我们可以在Docker上快速安装和部署Elasticsearch及其相关组件。这种方法不仅简化了安装过程,还方便了后续的维护和管理。希望这篇文章能帮助你快速上手Elasticsearch和Docker的结合使用。

相关推荐
bing.shao18 小时前
Goer-Docker系列-1-管理工具
docker·容器·eureka
MasonYyp18 小时前
Docker安装和使用kkfileview
运维·docker·容器
王煜苏18 小时前
contos7安装dokcer遇到的坑,docker-composer
docker·eureka·composer
DreamLife☼18 小时前
Docker-Dockerfile 完全指南:编写最佳实践的镜像
docker·镜像构建·多阶段构建·docker 安全·最小化镜像·非 root 用户·构建缓存
一念一花一世界19 小时前
Jenkins VS GitLab CI/CD VS Arbess,CI/CD工具选型指南
ci/cd·gitlab·jenkins·arbess
毛甘木20 小时前
阿里云CentOS环境下Docker Compose详细使用教程
阿里云·docker·centos
眠りたいです1 天前
基于脚手架微服务的视频点播系统-脚手架开发部分(完结)elasticsearch与libcurl的简单使用与二次封装及bug修复
c++·elasticsearch·微服务·云原生·架构·bug
N 年 后1 天前
Docker、Compose、Portainer与K8s详解
docker·容器·kubernetes
lihe7581 天前
DSM7.2部署可道云+onlyoffice在线办公系统
docker·onlyoffice·群晖·kodbox·docer-compose
失散131 天前
分布式专题——57 如何保证MySQL数据库到ES的数据一致性
java·数据库·分布式·mysql·elasticsearch·架构