使用Docker搭建ElasticSearch+Logstash+Kibana环境

最近在做 Spring Cloud 相关系列框架的搭建,在做到整合微服务跟踪-Sleuth后,项目添加了Sleuth后已经能够正常的输出跟踪信息日志,接下来要对整个日志进行分析处理,这里选取使用配合ELK来做,首先需要搭建整个ELK环境。

ELK介绍

ELK (官网)其实是三个不同的内容,一般配合一起使用。分别是:

  • ElasticSearch
  • Logstash
  • Kibana

具体的介绍可以看官网的每个产品介绍

Windows 环境搭建

可以参考:https://blog.csdn.net/pilihaotian/article/details/52452010 ,基本上比较详细了,但是也可以看出windows安装比较繁琐,而且还会耗费机器本身资源,本文介绍使用Docker安装搭建。

Docker 环境搭建

ELK对应的有很多版本,本文均使用最新版本

安装 elasticsearch

拉取镜像

    docker pull elasticsearch

启动容器

docker run -d -p 9200:9200 --name leon_elasticsearch elasticsearch

此时访问地址:<u>http://192.168.9.151:9200/</u>,看到如下效果说明启动成功:

1.jpg

安装插件 elasticsearch-head

一般情况下,安装插件只需要执行命令:

elasticsearch-plugin install mobz/elasticsearch-head

那么我们现在进入到容器中对应的目录:/usr/share/elasticsearch/bin/,然后执行上述命令,但是发现报错:


查阅相关文档得知以下信息:

– for Elasticsearch 5.x:
site plugins are not supported. Run elasticsearch-head as a standalone server

也就是说5.X以上的版本,需要单独启动 elasticsearch-head 服务。
那么单独启动运行插件容器:

docker run -d -p 9100:9100 --name leon_elasticsearch-head mobz/elasticsearch-head:5

注意后面跟的版本5,一定要对应自己的版本。

容器启动后,访问地址:</font><u>http://192.168.9.151:9100/</u>

2.jpg

此时代表插件服务已经启动,但是点击连接,发现无法连接elasticsearch服务,需要修改配置文件,文件地址为容器中的:/usr/share/elasticsearch/config/elasticsearch.yml

我们进入容器,发现无法使用VI命令修改文件,这个时候可以安装VI工具然后修改文件,或者使用另外一种粗暴的方法,在外面修改然后覆盖文件。这里因为安装VI总是出错,所以使用第二种方式。

首先将容器中的配置文件导出来:

docker cp leon_elasticsearch:/usr/share/elasticsearch/config/elasticsearch.yml /home/px2/elasticsearch.yml

在文件中添加以下内容:

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

然后在替换容器中的文件:

docker cp /home/px2/elasticsearch.yml leon_elasticsearch:/usr/share/elasticsearch/config/elasticsearch.yml

重启容器,然后重新访问:http://localhost:9100/ 就可以连接上了(此时还没有数据)

3.jpg

注意:如果还是不能连接,可以访问地址来连接:http://localhost:9100/?auth_user=elastic&auth_password=changeme

安装logstash

这里有个比较坑的问题,使用Docker官方Hub里的镜像 docker pull logstash 启动的容器总是会自动停掉,无法运行,后来选择使用官网中的镜像地址:

docker run --name leon_logstash docker.elastic.co/logstash/logstash:6.2.4

修改配置文件,进入容器:

docker exec -it leon_logstash /bin/bash

进入目录cd config
打开并修改配置文件 vi logstash.yml:

http.host: "0.0.0.0"
xpack.monitoring.elasticsearch.url: http://192.168.9.151:9200
xpack.monitoring.elasticsearch.username: elastic
xpack.monitoring.elasticsearch.password: changeme

安装kibana

拉取镜像

docker pull kibana

启动容器

docker run --name leon_kibana -p 5601:5601 -d -e ELASTICSEARCH_URL=http://192.168.9.151:9200 kibana

配置

访问地址:http://192.168.9.151:5601 ,看到如下效果

4.jpg

此时报错中间红色部分,无法进行创建,找到资料得知:

5.jpg

看官网的解释说这是因为初次设置的时候logstash没有加载到数据导致的。所以先要保证logstash能够加载到数据。

配置数据

进入到容器中:

docker exec -it leon_logstash /bin/bash

然后进入如下目录:
cd pipeline/
打开配置文件:vi logstash.conf

修改内容如下:

input {
        file {
            codec=> json
                path => "/usr/local/*.json"
        }
}
filter {
  #定义数据的格式
  grok {
    match => { "message" => "%{DATA:timestamp}\|%{IP:serverIp}\|%{IP:clientIp}\|%{DATA:logSource}\|%{DATA:userId}\|%{DATA:reqUrl}\|%{DATA:reqUri}\|%{DATA:refer}\|%{DATA:device}\|%{DATA:textDuring}\|%{DATA:duringTime:int}\|\|"}
  }
}
output {
   elasticsearch{
     hosts=> "http://192.168.9.151:9200"
   }
} 

其中指定了输出地址:elasticsearch的地址,而且还指定了内容输入地址:/usr/local/*.json,需要在usr/local下有json格式的数据,接下来将项目生成的json格式的日志文件上传到该目录。


docker cp /home/px2/logs/shop-user-consumer.json leon_logstash:/usr/local/shop-user-consumer.json
docker cp /home/px2/logs/shop-user-provider.json leon_logstash:/usr/local/shop-user-provider.json

然后重启logstash容器,在重新访问页面,可以看到可以进行create了。

6.jpg

点击create创建成功后,点击Discovery,选择时间为一年内,可以看到之前的数据:

7.jpg

并且访问9100地址也能加载出节点信息了:

8.png

至此,整个ELK环境就搭建起来了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容