Docker 部署 ELK 收集 Nginx 日志

1、简介

一、核心组成

ELK由Elasticsearch、Logstash和Kibana三部分组件组成;nginx

Elasticsearch是个开源分布式搜索引擎,它的特色有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful风格接口,多数据源,自动搜索负载等。web

 

Logstash是一个彻底开源的工具,它能够对你的日志进行收集、分析,并将其存储供之后使用docker

 

kibana 是一个开源和免费的工具,它能够为 Logstash 和 ElasticSearch 提供的日志分析友好的 Web 界面,能够帮助您汇总、分析和搜索重要数据日志。json

二、四大组件

Logstash: logstash server端用来搜集日志;vim

 

Elasticsearch: 存储各种日志;浏览器

 

Kibana: web化接口用做查寻和可视化日志;ruby

 

Logstash Forwarder: logstash client端用来经过lumberjack 网络协议发送日志到logstash server;bash

 

三、ELK工做流程

在须要收集日志的全部服务上部署logstash,做为logstash agent(logstash shipper)用于监控并过滤收集日志,将过滤后的内容发送到Redis,而后logstash indexer将日志收集在一块儿交给全文搜索服务ElasticSearch,能够用ElasticSearch进行自定义搜索经过Kibana 来结合自定义搜索进行页面展现。restful

 

第一步:上docker安装包网络

第二步:解压安装包,进行安装

[root@nginx ~]# tar zxf docker.tar.gz

[root@nginx ~]# cd docker

[root@nginx docker]# ls

ca.crt docker-app.tar.gz docker.sh remove.sh

[root@nginx docker]# sh docker.sh

docker

docker-compose

docker-containerd

docker-containerd-ctr

docker-containerd-shim

dockerd

docker-init

docker-proxy

docker-runc

Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /etc/systemd/system/docker.service.

第三步:查看是否安装成功

[root@nginx docker]# docker images

REPOSITORY TAG IMAGE ID CREATED SIZE

第四步:vm.max_map_count至少须要262144,永久修改vm.max_map_count方法以下图:

 直接执行以下命令:sysctl -w vm.max_map_count=262144

第五步:关闭防火墙

[root@docker ~]# systemctl stop firewalld

[root@docker ~]# setenforce 0

第六步:拉取ELK镜像

[root@nginx ~]# docker pull sebp/elk

第七步:下载镜像以后可使用docker的命令来验证是否成功,参考命令以下:

[root@nginx ~]# docker images

REPOSITORY TAG IMAGE ID CREATED SIZE

sebp/elk latest 0c1a88826f47 7 days ago 1.93GB

第八步:容器运行:运行此容器的时候,须要将宿主机的端口转发到该容器,其中ES端口为9200,kibana端口为5601,logbate端口为5044;建议将配置文件和数据存放在宿主机,便于后期维护,所以还须要将宿主机目录挂载到容器/data当中;最后构造的命令以下:

docker run -p  5601:5601 -p 9200:9200 -p 5044:5044  -v /Users/song/dockerFile:/data -it -d --name elk sebp/elk

第九步:检查端口是否开启

[root@nginx ~]# ss -tnl

第十步:数据导入与校验

容器运行以后,须要验证是否启动成功,经过浏览器访问kibana和ES的页面是否成功来判断。

http://localhost:5601/

当浏览器访问成功以后,参考以下图所示:

 

 

ES服务检查:验证kibana启动成功以后,接着继续验证ES服务是否启动成功,URL地址以下

http://localhost:9200/_search?pretty

访问以后,此时ES里面应该是没有数据的,出现的界面以下

 

 

第十一步:配置与验证

logstash配置:

logstash配置主要有三个地方要处理,首先是输入源在什么位置,而后是对数据进行过滤或者格式化,最后是须要将数据输出到什么地方;我在下方的配置只作了其中两项,由于在nginx日志当中已经将日志格式化了,编辑配置文件命令参考以下:

在/Users/song/dockerFile/目录下建立config目录,在config目录下建立logstash.yml文件

[root@nginx ~]# vim /Users/song/dockerFile/config/logstash.yml

input {

file {

path => "/data/logs/access.log"

codec => "json"

}

}

output {

elasticsearch { hosts => ["主机ip:9200"] }

stdout { codec => rubydebug }

}

在配置文件当中,能够看到日志文件存放的位置在 "/data/logs/access.log"当中,输出的地址是主机ip:9200,这是本机的ES服务

 

nginx日志格式

下载nginx

[root@nginx ~]# yum install nginx -y

更改nginx中的日志格式,将nginx的日志文件设置为json格式,在更改nginx配置文件以前,须要获取nginx配置文件路径,参考以下命令

[root@nginx ~]# sudo nginx -t

返回结果

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok

nginx: configuration file /etc/nginx/nginx.conf test is successful

在返回的结果当中已经能够看到配置文件所在的位置,使用vim编辑配置文件,参考命令

[root@nginx ~]# vim /etc/nginx/nginx.conf

http { log_format json '{"@timestamp":"$time_iso8601", "@version":"1","host":"$server_addr", "client":"$remote_addr", "size":"$body_bytes_sent", "responsetime":"$request_time", "domain":"$host","url":"$uri","status":"$status"}'; access_log /var/log/nginx/access.log json;

 

 

 

启动logstash

须要启动logstash开始收集日志,启动logstash以前须要先进入容器里面,进入容器参考命令以下:

[root@nginx ~]# docker exec -it elk bash

进入容器以后,须要启动logstash来收集数据,启动的时候须要带两个参数进去,第一个是logstash的数据暂存位置,第二个是使用的配置文件,所以构造的命令以下所示:

一、/opt/logstash/bin/logstash --path.data /tmp/logstash/data -f /data/config/logstash.yml

 

二、/opt/logstash/bin/logstash -e 'input { stdin { } } output { elasticsearch { hosts => ["localhost"] } }'

注意:若是看到报错信息:

Logstash could not be started because there is already another instance using the configured data directory.  If you wish to run multiple instances, you must change the "path.data" setting. 请执行命令:service logstash stop 而后在执行就能够了。

当命令成功被执行后,看到:Successfully started Logstash API endpoint {:port=>9600} 信息后,输入:this is a dummy entry 而后回车,模拟一条日志进行测试。

 

第十一步:添加数据

只要nginx产生日志,logstash就会实时将日志发送到ES服务当中,在发送数据时,终端窗口也会发生变化,以下图所示

kibana索引配置:

经过浏览器访问kibana,URL地址以下

http://127.0.0.1:5601/app/kibana#/management/kibana/index?_g=()

image

点击左侧导航栏的Discover连接,即可进入建立索引模式界面,以下图所示

image

点击页面右下方的next按钮,会跳转到下一个页面,在此页面还须要选择一个时间维度,以下图所示

image

在此点击下一步,便建立kibana的索引完成,此时再次点击左侧导航栏的Discover连接,即可以看到刚才建立索引的一些视图,以下图所示

image

在图中有一个input输入框,笔者能够在里面填写筛选所须要的关键词;若是没有筛选出结果,也可检查左侧的时间筛选项是否设置正确,如笔者的时间筛选项设置的是Today,也就表明筛选当天的数据。

ELK的总体操做流程比较简单,首先是logstash收集各类日志并进行过滤,而后将过滤后的内容发送到ES服务中,最后用户经过Kibana的页面查看ES中的日志数据;

相关文章
相关标签/搜索