前言

项目准备上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版本看是否安装成功


docker版本

如若之前安装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即可看到上一步拉取的镜像。


es镜像文章

有了镜像,就可以开始创建容器了,接下来创建一个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列出所有的容器。


es容器

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


返回结果

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

三、安装ElasticSearch-Head

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

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


安装ElasticSearch-Head插件

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

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

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

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

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

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


跨域问题

处理跨域

在连接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包


解压后的包

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

六、总结

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

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

坚持学习、坚持写作、坚持分享是咔咔从业以来所秉持的信念。但愿文章在偌大的互联网上能给你带来一点帮助,我是咔咔,下期见。

五分钟搞定Docker安装ElasticSearch的更多相关文章

  1. 五分钟搞定Go.js

    五分钟搞定Go.js  1.基于html5~因为Go.js是一个依赖于HTML5特性的JavaScript库,所以需要确保您的页面声明它是一个HTML5文档,当然需要加载库 <!DOCTYPE ...

  2. zookeeper-架构设计与角色分工-《每日五分钟搞定大数据》

    本篇文章阅读时间5分钟左右 点击看<每日五分钟搞定大数据>完整思维导图   zookeeper作为一个分布式协调系统,很多组件都会依赖它,那么此时它的可用性就非常重要了,那么保证可用性的同 ...

  3. zookeeper核心-zab协议-《每日五分钟搞定大数据》

    上篇文章<paxos与一致性>说到zab是在paxos的基础上做了重要的改造,解决了一系列的问题,这一篇我们就来说下这个zab. zab协议的全称是ZooKeeper Atomic Bro ...

  4. HDFS-异常大全-《每日五分钟搞定大数据》

    点击看<每日五分钟搞定大数据>完整思维导图以及所有文章目录 问题1:Decomminssioning退役datanode(即删除节点) 1.配置exclude: <name>d ...

  5. CENTOS --5分钟搞定Nginx安装的教程

    1. 安装gcc(centos 7之后一般已自带,可以在第6步失败后再安装) yum install gcc gcc-c++ 2. 安装pcre yum install -y pcre pcre-de ...

  6. 五分钟搞定 HTTPS 配置,二哥手把手教

    01.关于 FreeSSL.cn FreeSSL.cn 是一个免费提供 HTTPS 证书申请.HTTPS 证书管理和 HTTPS 证书到期提醒服务的网站,旨在推进 HTTPS 证书的普及与应用,简化证 ...

  7. 五分钟搞定Linux容器

    [TechTarget中国原创] Linux容器针对特定工作负载提供了全新的灵活性与可能性.存在很多解决方案,但是没有一个解决方案能够像systemd容器那样进行快速部署.给我五分钟,本文将介绍如何使 ...

  8. 5分钟搞定Nginx安装

      1. 安装gcc(centos 7之后一般已自带,可以在第6步失败后再安装) yum install gcc gcc-c++   2. 安装pcre yum install -y pcre pcr ...

  9. 五分钟搞定 Linux 文档全部知识,就看这篇文章

    作者:无痴迷,不成功 来源:见文末 写在前面 我们都知道Linux是一个支持多用户.多任务的系统,这也是它最优秀的特性,即可能同时有很多人都在系统上进行工作,所以千万不要强制关机,同时,为了保护每个人 ...

随机推荐

  1. Unittest方法 -- 测试套件

    TestSuite 测试固件 一. import unittestclass F6(unittest.TestCase): def setUp(self): pass def tearDown(sel ...

  2. .net 5+ 知新:【1】 .Net 5 基本概念和开发环境搭建

    最近一两年搞了很多其它事情,.net web方面的基本没做,之前做过几个小的项目零星的学习了些,从.net core 发布后其实都没正真的系统学习过. 就是上手做项目,平时也有关注和看些资料,所以项目 ...

  3. Debian10 / Ubuntu 20.10 /Linux Mint 20安装Microsoft Edge浏览器Dev版(每周更新)

    安装方法如下: 打开终端命令,切换到 管理员身份,输入如下安装命令即可在Linux下使用 Microsoft Edge 浏览器了 ## Setup curl https://packages.micr ...

  4. Python基础之创建文件夹与删除文件夹。

    参考链接:https://blog.csdn.net/weixin_43826242/article/details/87101436 创建目录结构 # 创建文件目录结构 def create_fol ...

  5. vue知识点----element UI+vue关于日期范围选择的操作,picker-options属性的使用

    需求场景如下: 指定起止日期,后选的将会受到先选的限制 不同的日期选择器,不过也存在关联关系 实现方法不难,利用了 change 事件,动态改变 picker-options 中的 disableDa ...

  6. ifix中嵌入3d模型初探(一)

    在ifix项目中插入3d模型,是当前工控上位机的一个发展趋势,故而我也来尝尝鲜.利用现有条件,初步打算完成一个工厂俯视3d全景. 基本思路:利用webbrowser+3dmax+three.js来嵌入 ...

  7. vue.js 贡献指南(翻译)

    Vue.js Contributing Guide vue 2.x 嗨! 我很高兴你有兴趣为Vue.js做贡献. 在提交您的贡献之前,请务必花点时间阅读以下指南. 行为守则 问题报告指南 PR指南 开 ...

  8. mongo-express 远程代码执行漏洞(CVE-2019-10758)

    影响版本 mongo-express 0.53.0 POST /checkValid HTTP/1.1 Host: 192.168.49.2:8081 Accept-Encoding: gzip, d ...

  9. 论文笔记:(ICML2020)On Learning Sets of Symmetric Elements

    目录 摘要 一.引言 二.先前的工作 三.基础 3.1 符号和基本定义 3.2 G-不变网络 3.3 描述等变层 3.4 Deep sets 四.DSS层 4.1 对称元素集合 4.2 等变层的表征 ...

  10. Java 反射(一)反射简介、原理和应用场景

    目录 一.动态语言和动态语言的比较 动态语言 静态语言 二.反射 简介 反射的常见使用 1. 代码编辑器 2. Spring等框架的IoC容器 3. 和注解的配合使用 原理 反射优缺点 调试查看 Cl ...