分享

ElasticSearch实战之用Docker安装



问题导读:

1、怎样拉取指定版本elasticsearch?
2、docker镜像参数有哪些?
3、怎样安装插件?




注意:本方案没有进行数据持久化,切勿用于生产环境

1. 安装docker
docker安装可参考此博客 Docker 从入门到实践系列二 - Docker 安装

2. 拉取elasticsearch镜像

拉取最新版本elasticsearch

  1. docker pull elasticsearch
复制代码

拉取指定版本elasticsearch,比如拉取7.11.1版本的elasticsearch

  1. docker pull elasticsearch:7.11.1
复制代码

3. 启动elasticsearch

  1. docker run --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms512m -Xmx512m" -d elasticsearch:7.11.1
复制代码

或者

  1. docker run --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms512m -Xmx512m" -d 54d1c07bc236
复制代码

运行docker镜像参数说明:

-p:端口映射

-e:设置环境变量,discovery.type=single-node(单机运行),ES_JAVA_OPTS="-Xms512m -Xmx512m"(设置JVM参数)

-d:后台启动

–name:容器名称

54d1c07bc236:镜像id

3.1 目录结构

  1. [root@node-123 systemd]# docker exec -it 54d1c07bc236 /bin/bash
  2. [root@54d1c07bc236 elasticsearch]# ls -l
  3. total 560
  4. -rw-r--r--  1 elasticsearch root   3860 Feb 15  2021 LICENSE.txt
  5. -rw-r--r--  1 elasticsearch root 545323 Feb 15  2021 NOTICE.txt
  6. -rw-r--r--  1 elasticsearch root   7263 Feb 15  2021 README.asciidoc
  7. drwxr-xr-x  2 elasticsearch root   4096 Feb 15  2021 bin
  8. drwxrwxr-x  1 elasticsearch root     55 Dec 23 09:40 config
  9. drwxrwxr-x  1 elasticsearch root     19 Dec 23 08:39 data
  10. drwxr-xr-x  1 elasticsearch root     17 Feb 15  2021 jdk
  11. drwxr-xr-x  3 elasticsearch root   4096 Feb 15  2021 lib
  12. drwxrwxr-x  1 elasticsearch root     71 Dec 23 09:41 logs
  13. drwxr-xr-x 57 elasticsearch root   4096 Feb 15  2021 modules
  14. drwxrwxr-x  1 elasticsearch root     25 Dec 23 09:40 plugins
复制代码

目录结构

目录 配置文件 描述
bin   脚本文件,包括启动 Elasticsearch、安装插件,运行统计数据等。
config elasticsearch.yml 集群配置文件
JDK Java 运行环境
data path.data 数据文件
lib   Java 类库
logs path.logs 日志文件
modules 包含所有 ES 模块
plugins 包含所有已安装插件
               
4. 验证elasticsearch是否启动成功

linux内用curl访问: curl http://localhost:9200,输入类似如下的信息表示安装成功

  1. {
  2.     "name": "54d1c07bc236",
  3.     "cluster_name": "docker-cluster",
  4.     "cluster_uuid": "5UUvjjKKRMeQG9FZvW_mxA",
  5.     "version": {
  6.         "number": "7.11.1",
  7.         "build_flavor": "default",
  8.         "build_type": "docker",
  9.         "build_hash": "ff17057114c2199c9c1bbecc727003a907c0db7a",
  10.         "build_date": "2021-02-15T13:44:09.394032Z",
  11.         "build_snapshot": false,
  12.         "lucene_version": "8.7.0",
  13.         "minimum_wire_compatibility_version": "6.8.0",
  14.         "minimum_index_compatibility_version": "6.0.0-beta1"
  15.     },
  16.     "tagline": "You Know, for Search"
  17. }
复制代码

5. 插件安装

5.1 安装IK分词器

插件安装可以用elasticsearch-plugin install url命令

比如安装:elasticsearch-analysis-ik(分词器),Ik分词器版本要和ES和Kibana版本保持一致

docker进入容器命令,容器id为 54d1c07bc236

  1. docker exec -it 54d1c07bc236 /bin/bash
复制代码

plugins安装步骤

  1. cd /usr/share/elasticsearch/plugins/
复制代码

安装插件,elasticsearch-analysis-ik版本与elasticsearch保持一致,即7.11.1

  1. elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.11.1/elasticsearch-analysis-ik-7.11.1.zip
复制代码

退出容器

  1. exit
复制代码

重启docker容器

  1. docker restart 54d1c07bc236
复制代码

5.2 分词器使用验证

ik_smart:智能分词,最少切分,宁缺毋滥,保证查准率

ik_max_word:最大化分词法,最细粒度划分,尽量多的有意义的分词,保证查全率,ik_max_word分词包含 ik_smart

Postman post请求分词测试:http://ip:9200/_analyze

  1. {
  2.     "tokenizer": "ik_smart",
  3.     "text": "花城广州"
  4. }
复制代码

结果如下:

  1. {
  2.     "tokens": [
  3.         {
  4.             "token": "花城",
  5.             "start_offset": 0,
  6.             "end_offset": 2,
  7.             "type": "CN_WORD",
  8.             "position": 0
  9.         },
  10.         {
  11.             "token": "广州",
  12.             "start_offset": 2,
  13.             "end_offset": 4,
  14.             "type": "CN_WORD",
  15.             "position": 1
  16.         }
  17.     ]
  18. }
复制代码

6. kibana安装

6.1 docker安装kibana

安装kibana版本与elasticsearch版本一致,即7.11.1

  1. docker pull kibana:7.11.1
复制代码

6.2 启动kibana

安装完成以后需要启动kibana容器,使用–link连接到elasticsearch容器,命令如下:

  1. docker run --name kibana --link=elasticsearch:elasticsearch -p 5601:5601 -d kibana:7.11.1
复制代码

启动以后可以打开浏览器输入http://ip:5601就可以打开kibana的界面了。

09d7b577689c4120a70770077799cc89.png

7、elasticsearch-head安装

elasticsearch-head是用于Elasticsearch监控的插件

镜像 pull

  1. docker pull mobz/elasticsearch-head:5
复制代码

查看镜像

  1. docker images
复制代码

输出结果包含mobz/elasticsearch-head

  1. REPOSITORY                TAG       IMAGE ID       CREATED         SIZE
  2. hello-world               latest    feb5d9fea6a5   3 months ago    13.3kB
  3. elasticsearch             7.11.1    bc3d45eba361   10 months ago   819MB
  4. kibana                    7.11.1    ecf6e21a953f   10 months ago   1.01GB
  5. mobz/elasticsearch-head   5         b19a5c98e43b   4 years ago     824MB
复制代码

启动容器

  1. docker run -d --name elasticsearch-head -p 9100:9100 mobz/elasticsearch-head:5
复制代码

浏览器访问(http://ip:9100/),结果如下:

fc0900c3971e4b18b1ceb7ea39801bb3.png

8、常见问题处理

开始链接elasticsearch服务,会发现链接不上,由于是前后端分离开发,所以会存在跨域问题,需要在服务端做CORS的配置

  1. docker exec -it elasticsearch /bin/bash
  2. vi config/elasticsearch.yml
复制代码

在elasticsearch.yml的文件末尾添加如下配置,保存,退出容器,并重启

  1. http.cors.enabled: true
  2. http.cors.allow-origin: "*"
复制代码

参数说明:

参数缺省值 说明
http.cors.enabled false 是否支持跨域,默认为false
http.cors.allowed.origin localhost  当设置允许跨域,默认为*,表示支持所有域名,如果我们只是允许某些网站能访问,那么可以使用正则表达式。比如只允许本地地址。 /https?😕/localhost(:[0-9]+)?/
http.cors.max-age 1728000(20天) 浏览器发送一个“预检”OPTIONS请求,以确定CORS设置。最大年龄定义多久的结果应该缓存。
http.cors.allow-methods OPTIONS,HEAD,GET,POST,PUT,DELETE 允许跨域的请求方式
http.cors.allow-headers X-Requested-With,Content-Type,Content-Length 跨域允许设置的头信息
http.cors.allow-credentials 是否返回设置的跨域Access-Control-Allow-Credentials头,如果设置为true,那么会返回给客户端。
               
退出容器

  1. exit
复制代码

重启elasticsearch

执行,54d1c07bc236为elasticsearch容器id

  1. docker restart 54d1c07bc236
复制代码

或者

  1. docker restart elasticsearch
复制代码

浏览器再次访问(http://ip:9100/),记得修改elasticsearch地址,显示【集群健康值: green】表示连接elasticsearch成功

3f06214b28444a529fd62d05d21bf635.png





最新经典文章,欢迎关注公众号



---------------------

作者:ThinkWon
来源:csdn
原文:Docker安装ElasticSearch和Kibana



没找到任何评论,期待你打破沉寂

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条