在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
前言项目准备上ElasticSearch,为了后期开发不卡壳只能笨鸟先飞,在整个安装过程中遇到以下三个问题。
一、安装Docker目前咔咔对Docker的理解还只是个皮毛,对于不了解的东西就要多多使用,使用的多了自然而然也就会了。 安装依赖包,执行命令 此时若直接执行安装docker命令就会发现是十分慢的,这个等待过程是漫长的。 配置国内的源就可以解决问题 接着再执行命令 配置docker开机自启 执行 查看docker版本看是否安装成功 如若之前安装docker有问题,那么执行 docker安装完成后咔咔就进行了创建容器,但遇到了一个问题 拿着这个错误直接找度娘才知道,没有开启转发,网络桥接配置后,是需要开启转发的。 若不开启转发就会出现上边的错误,显示没有网络。 解决方案 修改配置文件 二、安装ElasticSearch使用docker直接获取es镜像,执行命令 执行完成后,执行docker images即可看到上一步拉取的镜像。 有了镜像,就可以开始创建容器了,接下来创建一个es的容器。 执行
命令执行完成会返回容器id,此时再执行docker ps -a列出所有的容器。 es默认端口为9200,只用ip地址+端口号直接访问,就会返回如下图。出现这个界面就表示你安装成功了。 到这里我们就非常快速的使用Docker安装完成了ElasticSearch,接下来再一起安装针对于ElasticSearch的客户端工具。 三、安装ElasticSearch-Head同样也采用Docker进行快速安装,跟上边一样同样先拉取镜像,执行命令 接着创建容器,执行 为了保证图片的清晰度,图片就没有截取完全,同时也是咔咔接下来将要跟你讲的,注意俩次创建容器时的不同。 安装ElasticSearch时是容器创建成功后直接在后台就运行了,但在安装ElasticSearch-Head时并没有保持一致。 而是指定容器名,端口号就直接执行了,这样执行完成后是创建了一个容器,并没有运行。 也就是咔咔在上图右下角的地方有一个框,这里就可以看到状态,会发现是create。 所以还需要一个操作,那就是启动容器 安装完成直接使用 处理跨域 在连接ElasticSearch会发现无法连接,由于时前后端分离开发,所以会存在跨域问题,需要在服务端做跨域处理。 执行命令
将上边俩行写进配置文件中,注意这里是用yml的配置文件,简单普及一下此类配置文件的几点语法。
配置修改完后需执行命令 处理报406错误 此时通过 只需要修改ElasticSearch-Head容器中的配置即可,将配置文件复制到宿主机进行修改。 执行 进入到/usr/local即可看到从容器中复制出来的文件vendor.js。 修改文件第6886、7574行,将"application/x-www-from-urlencodes"修改为"application/json;charset=UTF-8"即可 修改后再将文件复制到容器中,从容器复制文件到宿主机命令已经使用过了,那么现在只不过是把俩个目录反过来即可执行 最后一步 四、安装IK分词器首先问一个问题,ElasticSearch中自带的有分词器为什么还要使用IK分词器? 在ElasticSearch中的分词器会把中文分为一个一个的字,例如"今天是周五",会被分成“今”、“天”、“是”,“周”、“五”,这里很明显是不合适的,在大多数场景下需要的是词而不是字。 所以就需要安装中文分词器IK来解决这个问题。 IK提供了两个分词算法:ik_smart和ik_max_word,其中ik_smart为最少切分,ik_max_word为最细力度。分别都有什么区别会在下期文章中给大家提出来。 这里需要注意安装的版本需要跟ElasticSearch版本一致。 进入到ElasticSearch容器中 使用wget来进行安装,执行 当你使用wget安装出现
执行 将压缩包移动到 接着删除压缩包即可,此时你可以看到一个config包和几个jar包 最后退出容器,重启重启容器即可。 五、总结本期文章将需要使用ElasticSearch所有的东西都已经准备齐全了,接下来的文章会带着你使用PHP的Laravel开始封装ElasticSearch的所有查询方法。 后期也会在Go中封装一份,给自己的工具类添加一点内容。 到此这篇关于一文搞定Docker安装ElasticSearch的过程的文章就介绍到这了,更多相关Docker安装ElasticSearch内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论