Docker安装ElasticSearch

我是参考这几篇博客。

参考这几篇博客,然后自己成功后,做一个记录。大家都可以去看看

https://blog.csdn.net/qq_40942490/article/details/111594267
https://zhuanlan.zhihu.com/p/257867352
https://www.cnblogs.com/fkaka/p/15205675.html

第一步:确保你的虚拟机或者是服务器已经安装了Docker

没有安装的可以参考这个docker安装

第二步:安装ElasticSearch

这次安转的7.7.0的版本

安装

使用docker 直接获取es的镜像

docker pull elasticsearch:7.7.0

命令执行完后,使用docker images查看镜像是否拉取成功
在这里插入图片描述
ok,下载成功了!

执行

镜像下载成功,使用镜像创建容器。

修改配置文件

mkdir -p /mydata/elasticsearch/config
mkdir -p /mydata/elasticsearch/data/
mkdir -p /mydata/elasticsearch/plugins
echo "http.host: 0.0.0.0" >> /mydata/elasticsearch/config/elasticsearch.yml
chmod -R 777 file
启动容器

注意:启动前需要在服务器新建下列文件夹,并且文件夹的权限要改成使用chmod -R 777 file修改文件读写权限

docker run --name elasticsearch -p 9200:9200 -p 9300:9300 
-e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms512m -Xmx512m" 
-v /mydata/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml 
-v /mydata/elasticsearch/data/:/usr/share/elasticsearch/data 
-v /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins 
-d elasticsearch:7.7.0

参数说明:

--name表示镜像启动后的容器名称  

-d: 后台运行容器,并返回容器ID;

-e: 指定容器内的环境变量

-p: 指定端口映射,格式为:主机(宿主)端口:容器端口

discovery.type=single-node:单机运行

如果启动不了,可以加大内存设置:-e ES_JAVA_OPTS="-Xms512m -Xmx512m"

使用docker ps查看一下:
在这里插入图片描述

查看

es默认端口为9200,只用ip地址+端口号直接访问,所以在浏览器中输入ip:9200,如果出现以下界面就是安装成功了!
在这里插入图片描述
ok!到此。ElasticSearch:7.7.0安装成功了!

安装ElasticSeach的一些工具

安装ElasticSeach-head

安装

同样使用docker进行安装。先拉取镜像,使用下面的命令:

#拉取镜像
docker pull mobz/elasticsearch-head:5

使用docker images,查看镜像是否拉取成功
在这里插入图片描述

启动容器
#创建容器
docker create --name elasticsearch-head -p 9100:9100 mobz/elasticsearch-head:5

#启动容器
docker start elasticsearch-head
  • 安装ElasticSearch时是容器创建成功后直接在后台就运行了,但在安装ElasticSearch-Head时并没有保持一致。
  • 而是指定容器名,端口号就直接执行了,这样执行完成后是创建了一个容器,并没有运行。
  • 所以还需要一个操作,那就是启动容器docker start 容器id。
  • 安装完成直接使用域名加端口9100即可访问。
    在这里插入图片描述
处理跨域

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

docker exec -it elasticsearch(或者容器id) /bin/bash

在这里插入图片描述

进入到第一步创建的ElasticSearch容器中,修改配置文件

vi/vim config/elasticsearch.yml

在这里插入图片描述
把这两行写进配置文件中(注意是yml配置文件):

http.cors.enabled: true 
http.cors.allow-origin: "*"

在这里插入图片描述
配置修改完后需执行命令exit退出容器,接着执行docker restart 容器ID重启容器即可。

处理406和es-head不显示数据的问题

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

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

#复制vendor.js到外部
docker cp 容器id:/usr/src/app/_site/vendor.js /usr/local/

#修改vendor.js
vim vendor.js

进入到/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

docker cp /usr/local/vendor.js  容器id:/usr/src/app/_site

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

docker restart 容器id

安装IK分词器

首先问一个问题,ElasticSearch中自带的有分词器为什么还要使用IK分词器?
在ElasticSearch中的分词器会把中文分为一个一个的字,例如"今天是周五",会被分成“今”、“天”、“是”,“周”、“五”,这里很明显是不合适的,在大多数场景下需要的是词而不是字。
所以就需要安装中文分词器IK来解决这个问题。
IK提供了两个分词算法:ik_smart和ik_max_word,其中ik_smart为最少切分,ik_max_word为最细力度。
这里需要注意安装的版本需要跟ElasticSearch版本一致。

第一种离线安装

下载ik分词器压缩包:ik分词器:7.7.0
使用xftp将分词器上传到服务器或者虚拟机中的/tmp中

#将压缩包移动到容器中
docker cp /tmp/elasticsearch-analysis-ik-7.7.0.zip elasticsearch:/usr/share/elasticsearch/plugins

#进入容器
docker exec -it elasticsearch /bin/bash  

#创建目录
mkdir /usr/share/elasticsearch/plugins/ik

#将文件压缩包移动到ik中
mv /usr/share/elasticsearch/plugins/elasticsearch-analysis-ik-7.7.0.zip /usr/share/elasticsearch/plugins/ik

#进入目录
cd /usr/share/elasticsearch/plugins/ik

#解压
unzip elasticsearch-analysis-ik-7.7.0.zip

#删除压缩包
rm -rf elasticsearch-analysis-ik-7.7.0.zip

退出并重启镜像

第二种使用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包

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

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用Docker安装Elasticsearch的步骤: 1. 确保您已经安装DockerDocker Compose。如果您还没有安装,请按照官方文档进行安装。 2. 创建一个新的目录,例如`elasticsearch`,用于存储Elasticsearch配置和数据。 3. 在该目录中创建一个名为`docker-compose.yml`的文件,并将以下内容添加到该文件中: ``` version: '3' services: elasticsearch: image: docker.elastic.co/elasticsearch/elasticsearch:7.18.0 container_name: elasticsearch environment: - node.name=elasticsearch - discovery.type=single-node ulimits: memlock: soft: -1 hard: -1 volumes: - ./data:/usr/share/elasticsearch/data ports: - 9200:9200 - 9300:9300 ``` 此文件定义了一个名为`elasticsearch`的Docker服务。我们使用7.18.0版本的Elasticsearch镜像,将容器命名为`elasticsearch`,并将环境变量设置为`node.name`和`discovery.type`以使其成为单节点集群。我们还将内存锁定限制设置为无限制,并将Elasticsearch数据存储在我们创建的名为`data`的本地目录中。最后,我们将容器的端口映射到主机的9200和9300端口,以便我们可以通过HTTP和Transport协议访问Elasticsearch。 4. 在终端中导航到`elasticsearch`目录,并运行以下命令以启动Elasticsearch服务: ``` docker-compose up -d ``` 这将使用我们在`docker-compose.yml`文件中定义的配置启动一个名为`elasticsearch`的Docker容器。 5. 要验证Elasticsearch是否正在运行,请运行以下命令: ``` curl -X GET "localhost:9200" ``` 如果您看到Elasticsearch的版本信息,则表示它已成功安装并正在运行。 现在您已经成功地使用Docker安装Elasticsearch,可以开始在其上构建应用程序或进行数据分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值