五分钟搞定Docker安装ElasticSearch

本文涉及的产品
Elasticsearch Serverless通用抵扣包,测试体验金 200元
简介: 五分钟搞定Docker安装ElasticSearch

前言

项目准备上ElasticSearch,为了后期开发不卡壳只能笨鸟先飞,在整个安装过程中遇到以下三个问题。


Docker安装非常慢

ElasticSearch-Head连接出现跨域

ElasticSearch-Head操作报出406错误码

一、安装Docker

目前咔咔对Docker的理解还只是个皮毛,对于不了解的东西就要多多使用,使用的多了自然而然也就会了。


安装依赖包,执行命令yum install -y yum-utils device-mapper-persistent-data lvm2


此时若直接执行安装docker命令就会发现是十分慢的,这个等待过程是漫长的。


配置国内的源就可以解决问题yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo这里使用的是阿里云的源。


接着再执行命令yum install docker-ce docker-ce-cli containerd.io安装docker即可。


配置docker开机自启systemctl enable docker


执行systemctl start docker命令启动docke


查看docker版本看是否安装成功


image.png


如若之前安装docker有问题,那么执行yum remove docker-ce来删除并且将/var/lib/docker下的所有东西全部删除干净。


docker安装完成后咔咔就进行了创建容器,但遇到了一个问题WARNING: IPv4 forwarding is disabled. Networking will not work.


拿着这个错误直接找度娘才知道,没有开启转发,网络桥接配置后,是需要开启转发的。


若不开启转发就会出现上边的错误,显示没有网络。


解决方案


修改配置文件/etc/sysctl.conf,在里边加上net.ipv4.ip_forward=1,然后重启服务systemctl restart network,让配置生效。


二、安装ElasticSearch

使用docker直接获取es镜像,执行命令docker pull elasticsearch:7.7.0


执行完成后,执行docker images即可看到上一步拉取的镜像。


image.png


有了镜像,就可以开始创建容器了,接下来创建一个es的容器。


执行docker run --name elasticsearch -d -e ES_JAVA_OPTS="-Xms512m -Xmx512m" -e "discovery.type=single-node" -p 9200:9200 -p 9300:9300 elasticsearch:7.7.0


--name 表示容器名称  
-d: 后台运行容器,并返回容器ID;
-e: 指定容器内的环境变量
-p: 指定端口映射,格式为:主机(宿主)端口:容器端口


命令执行完成会返回容器id,此时再执行docker ps -a列出所有的容器。


image.png


es默认端口为9200,只用ip地址+端口号直接访问,就会返回如下图。出现这个界面就表示你安装成功了。

image.png



到这里我们就非常快速的使用Docker安装完成了ElasticSearch,接下来再一起安装针对于ElasticSearch的客户端工具。


三、安装ElasticSearch-Head

同样也采用Docker进行快速安装,跟上边一样同样先拉取镜像,执行命令docker pull mobz/elasticsearch-head:5


接着创建容器,执行docker create --name elasticsearch-head -p 9100:9100 mobz/elasticsearch-head:5


image.png


为了保证图片的清晰度,图片就没有截取完全,同时也是咔咔接下来将要跟你讲的,注意俩次创建容器时的不同。


安装ElasticSearch时是容器创建成功后直接在后台就运行了,但在安装ElasticSearch-Head时并没有保持一致。


而是指定容器名,端口号就直接执行了,这样执行完成后是创建了一个容器,并没有运行。


也就是咔咔在上图右下角的地方有一个框,这里就可以看到状态,会发现是create。


所以还需要一个操作,那就是启动容器docker start 容器id。


安装完成直接使用域名加端口9100即可访问。


image.png


处理跨域


在连接ElasticSearch会发现无法连接,由于时前后端分离开发,所以会存在跨域问题,需要在服务端做跨域处理。


执行命令docker exec -it elasticsearch /bin/bash 进入到第一步创建的ElasticSearch容器中,修改配置文件vi config/elasticsearch.yml即可。


http.cors.enabled: true

http.cors.allow-origin: "*"



将上边俩行写进配置文件中,注意这里是用yml的配置文件,简单普及一下此类配置文件的几点语法。


冒号后边必须有一个空格

使用空格的缩进标识层级关系,空格数据不重要,只要是左边对其的一列键即可。

对大小写十分敏感

缩进时不允许使用tab,只允许使用空格。

配置修改完后需执行命令exit退出容器,接着执行docker restart 容器ID重启容器即可。


处理报406错误


此时通过ElasticSearch-Head可以成功连接ElasticSearch了,但进行数据操作时会报406错误。


只需要修改ElasticSearch-Head容器中的配置即可,将配置文件复制到宿主机进行修改。


执行docker cp 容器ID:/usr/src/app/_site/vendor.js /usr/local/ ,此命令会把docker容器中的文件复制到你的宿主机目录。


进入到/usr/local即可看到从容器中复制出来的文件vendor.js。


修改文件第6886、7574行,将"application/x-www-from-urlencodes"修改为"application/json;charset=UTF-8"即可


修改后再将文件复制到容器中,从容器复制文件到宿主机命令已经使用过了,那么现在只不过是把俩个目录反过来即可执行docker cp /usr/local/vendor.js 容器ID:/usr/src/app/_site


最后一步重启ElasticSearch-Head容器就结束了。


四、安装IK分词器

首先问一个问题,ElasticSearch中自带的有分词器为什么还要使用IK分词器?


在ElasticSearch中的分词器会把中文分为一个一个的字,例如"今天是周五",会被分成“今”、“天”、“是”,“周”、“五”,这里很明显是不合适的,在大多数场景下需要的是词而不是字。


所以就需要安装中文分词器IK来解决这个问题。


IK提供了两个分词算法:ik_smart和ik_max_word,其中ik_smart为最少切分,ik_max_word为最细力度。分别都有什么区别会在下期文章中给大家提出来。


这里需要注意安装的版本需要跟ElasticSearch版本一致。


进入到ElasticSearch容器中docker exec -it 容器ID /bin/bash


使用wget来进行安装,执行wget https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.7.0/elasticsearch-analysis-ik-7.7.0.zip即可。


当你使用wget安装出现Unable to establish SSL connection时执行以下俩个命令即可。


yum install opensslls


yum install openssl-devel


执行cd /usr/share/elasticsearch/plugins来到插件目录创建一个IK目录。


将压缩包移动到IK目录中,执行解压指令elasticsearch-analysis-ik-7.7.0.zip


接着删除压缩包即可,此时你可以看到一个config包和几个jar包


image.png


最后退出容器,重启重启容器即可。


六、总结

本期文章将需要使用ElasticSearch所有的东西都已经准备齐全了,接下来的文章会带着你使用PHP的Laravel开始封装ElasticSearch的所有查询方法。


后期也会在Go中封装一份,给自己的工具类添加一点内容。


相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。  
相关文章
|
3月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
17天前
|
关系型数据库 数据库 PostgreSQL
docker 安装 Postgres 17.6
本文介绍如何通过Docker安装和配置PostgreSQL 17.6。内容包括拉取镜像、导出配置文件、运行容器并挂载数据与配置文件目录,以及进入容器使用psql操作数据库的完整步骤,便于持久化管理和自定义配置。
113 3
docker 安装 Postgres 17.6
|
6月前
|
存储 安全 C++
Odoo 安装方式选择:源码安装 vs Docker
Odoo部署常采用源码编译或Docker容器化,但分别面临依赖复杂、版本风险和服务化难题,以及镜像臃肿和扩展受限的问题。Websoft9提出混合方案,融合两者优势:通过智能环境适配、三阶段部署流程(环境预检、混合模式选择、持久化配置)及声明式YAML配置,实现高效、灵活的双模运行时。此方案显著降低依赖冲突解决时间(从83分钟至0),生产环境构建耗时缩短至8分钟,并达100% CVE漏洞修复率,适合ERP定制开发与规模化部署的企业需求。
|
4月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
422 4
|
3月前
|
Linux Docker Windows
windows docker安装报错适用于 Linux 的 Windows 子系统必须更新到最新版本才能继续。可通过运行 “wsl.exe --update” 进行更新。
适用于 Linux 的 Windows 子系统需更新至最新版本(如 wsl.2.4.11.0.x64.msi)以解决 2025 年 Windows 更新后可能出现的兼容性问题。用户可通过运行 “wsl.exe --update” 或访问提供的链接下载升级包进行更新。
888 0
|
4月前
|
Linux iOS开发 Docker
MyEMS开源系统安装之Linux/macOS上的DOcker
本指南详细介绍了如何在Linux/macOS上使用Docker部署MyEMS系统。主要内容包括:前置条件(如安装Docker、npm和MySQL),以及分步骤部署各个组件(如myems-api、myems-admin、myems-modbus-tcp等)。每个步骤涵盖源代码复制、环境配置、镜像构建、容器运行及日志管理等操作,并提供了多平台构建的支持。最后,指南还说明了默认端口和登录凭据,帮助用户快速启动并访问MyEMS的管理界面和Web界面。
133 1
|
5月前
|
关系型数据库 MySQL 数据库
Docker 安装常用软件相关命令
本文介绍了在CentOS 7.9系统上安装Docker的详细步骤,包括添加阿里云镜像源、安装Docker及相关组件、启动服务以及配置镜像加速。同时,还展示了如何通过Docker安装MySQL 5.7版本数据库,涵盖拉取镜像、创建数据目录、运行容器及配置挂载点等操作,并提供验证安装成功的命令和截图。适合需要部署Docker与MySQL环境的用户参考。
313 5