返回顶部
首页 > 资讯 > 精选 >怎么在Docker中搭建ELK 日志系统
  • 449
分享到

怎么在Docker中搭建ELK 日志系统

2023-06-15 04:06:34 449人浏览 独家记忆
摘要

怎么在Docker中搭建elk 日志系统?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。ELK介绍:ELK是三个开源软件的缩写,分别为:elasticsearch

怎么在Docker中搭建elk 日志系统?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

ELK介绍:

怎么在Docker中搭建ELK 日志系统

ELK是三个开源软件的缩写,分别为:elasticsearch 、 Logstash以及Kibana , 它们都是开源软件。 目前由于原本的ELK Stack成员中加入了 Beats 工具所以已改名为Elastic Stack。 Beats,它是一个轻量级的日志收集处理工具(Agent),占用资源少,适合于在各个服务器上搜集日志后传输给Logstash,官方也推荐此工具。

怎么在Docker中搭建ELK 日志系统

搭建步骤:

经过上述描述,大家也应该稍微有点了解了,想要搭建这个平台至少是需要3/4个软件的(可以没有filebeat)。

  • kibana 用于展示

  • elasticsearch 用于检索

  • logstash 用于过滤

  • filebeat 用于收集日志

本篇文章假定你已经有了docker环境,并且有基本的docker使用经验

拉取镜像(统一版本可以避免很多坑):

docker pull kibana:6.8.2docker pull elasticsearch:6.8.2docker pull mobz/elasticsearch-head:5 # es的一个插件docker pull logstash:6.8.2docker pull docker.elastic.co/beats/filebeat:6.8.2 # 很慢 可以尝试设置代理或者更改docker镜像源

Docker 设置代理在linux中可以使用ClashX 订阅url,然后docker 连到代理。有桌面的可以直接更改,没有的也可以创建配置文件进行更改 ⇒ 传送门

怎么在Docker中搭建ELK 日志系统

另外把docker的内存给多一点儿,避免到时候卡顿。


构建ES:

docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch -e "discovery.type=single-node" elasticsearch:6.8.2

浏览器访问(curl也行):localhost:9200 出现下面的结果则说明启动成功:

怎么在Docker中搭建ELK 日志系统

若出现错误,请查错误日志。

创建ES-HEAD:

docker run -d -p 9100:9100 docker.io/mobz/elasticsearch-head:5

同样访问localhost:9100,看到下面的结果即为成功:

怎么在Docker中搭建ELK 日志系统

在es-head连接es可能是连不上的,是因为es没有开启跨域,进入es容器内部 找到config文件下的elasticsearch.yml,在此文件中增加:

Http.cors.enabled: truehttp.cors.allow-origin: "*"

然后重启es后es-head就可以连接上es。

开启Kibana:

docker run -d -p 5601:5601 --link elasticsearch -e ELASTICSEARCH_URL=http://elasticsearch:9200 kibana:6.8.2

这里就是http://elasticsearch:9200,不要更改,前面使用了–link,会在kibana容器hosts文件中加入elasticsearch ip地址,这样我们就直接通过定义的name来访问es服务了。
容器启动成功后,es-head里面应该就能看到下面的信息:

怎么在Docker中搭建ELK 日志系统

访问localhost:5601会出现下面的结果:

怎么在Docker中搭建ELK 日志系统

至此我们的kibana已经成功跑起来了,es也已经跑起来了,接下来就是收集日志的服务了。

构建filebeat 和 logstash:

首先声明,这两兄弟需要点儿配置文件,我们想整个文件夹统一存放这两份配置文件:

mkdir elktest  # 在主目录下 即:~/elktest 路径cd elktesttouch filebeat.ymltouch logstash.conf

添加配置文件

vim filebeat.yml
filebeat.prospectors:- paths:    - /home/elk/logs/user/a.log  multiline:      pattern: ^\d{4}      negate: true      match: after  fields:    doc_type: user- paths:    - /home/elk/logs/service/a.log  multiline:      pattern: ^\d{4}      negate: true      match: after  fields:    doc_type: serviceoutput.logstash: # 输出地址  hosts: ["logstash:5044"]
vim logstash.conf
input {  beats {    port => "5044"  }}filter {  JSON {    source => "message"  }}output {  stdout { codec => rubydebug }  elasticsearch {        hosts => [ "elasticsearch:9200" ]        index => "%{[fields][doc_type]}-%{+YYYY.MM.dd}"    }}

当前你应该还在elktest目录下,由于我们没有日志来源,所以本片的方式是手动创建日志,建立一个日志文件夹:

mkdir logdir

自己构建一些日志,随便写什么,文件及文件夹名称不要改动,已经在配置文件中对应好了,构建完成之后你的目录结构应该长这个样子:

怎么在Docker中搭建ELK 日志系统

创建容器:

docker run -it --name logstash --link elasticsearch -d -p 5044:5044 -v ~/elktest/logstash.conf:/usr/share/logstash/pipeline/logstash.conf logstash:6.8.2docker run --name filebeat --link logstash -d -v ~/elktest/filebeat.yml:/usr/share/filebeat/filebeat.yml -v ~/elktest/logdir/user/:/home/elk/logs/user/ -v ~/elktest/logdir/service/:/home/elk/logs/service/ docker.elastic.co/beats/filebeat:6.8.2

此时你的es-head应该长这个样子:

怎么在Docker中搭建ELK 日志系统

如果不是这个样子,可以查看容器是否运行,是否有错误日志,另外也可以到logstash容器中ping elasticsearch,filebeat容器中ping logstash,检查路径是否有问题。

Kibana显示: 创建索引向:

怎么在Docker中搭建ELK 日志系统

创建完成后去查看,添加自己想要查看的字段,内容在message里(刚好就是我们在a.log中的内容):

怎么在Docker中搭建ELK 日志系统

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网精选频道,感谢您对编程网的支持。

--结束END--

本文标题: 怎么在Docker中搭建ELK 日志系统

本文链接: https://lsjlt.com/news/277732.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么在Docker中搭建ELK 日志系统
    怎么在Docker中搭建ELK 日志系统?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。ELK介绍:ELK是三个开源软件的缩写,分别为:Elasticsearch...
    99+
    2023-06-15
  • 如何使用Docker搭建ELK日志系统
    本篇内容主要讲解“如何使用Docker搭建ELK日志系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Docker搭建ELK日志系统”吧!以下安装都是以...
    99+
    2024-04-02
  • 基于Docker搭建ELK 日志系统的方法
    背景需求:     业务发展越来越庞大,服务器越来越多 各种访问日志、应用日志、错误日志量越来越多,导致运维人员无法很好的去管理日志 开发人员...
    99+
    2024-04-02
  • ELK搭建线上日志收集系统
    目录ELK环境安装docker-compose脚本安装要点分场景收集日志Logback配置详解完全配置配置要点解析使用默认的日志配置springPropertyfilterappen...
    99+
    2024-04-02
  • 怎么用ELK搭建TB级的日志监控系统
    这篇文章主要介绍了怎么用ELK搭建TB级的日志监控系统,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在企业级的微服务环境中,跑着成百上千个服务都算是比较小的规模了。在生产环境...
    99+
    2023-06-17
  • Docker中怎么部署ELK和Filebeat日志中心
    本文小编为大家详细介绍“Docker中怎么部署ELK和Filebeat日志中心”,内容详细,步骤清晰,细节处理妥当,希望这篇“Docker中怎么部署ELK和Filebeat日志中心”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来...
    99+
    2023-06-27
  • Docker compose搭建ELK服务怎么使用
    今天小编给大家分享一下Docker compose搭建ELK服务怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2023-07-05
  • Linux系统怎么搭建日志服务器
    本文小编为大家详细介绍“Linux系统怎么搭建日志服务器”,内容详细,步骤清晰,细节处理妥当,希望这篇“Linux系统怎么搭建日志服务器”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、 Relp方式传送日志(高...
    99+
    2023-06-28
  • docker怎么部署EFK日志系统
    这篇文章主要介绍“docker怎么部署EFK日志系统”,在日常操作中,相信很多人在docker怎么部署EFK日志系统问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”docker怎么部署EFK日志系统”的疑惑有所...
    99+
    2023-06-04
  • ELK日志系统中如何进行通用应用程序日志接入
    这篇文章给大家介绍ELK日志系统中如何进行通用应用程序日志接入,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。日志规范规范的日志存放路径和输出格式将为我们后续的收集和分析带来极大的方便,无需考虑各种不同路径、格式的兼容问...
    99+
    2023-06-19
  • 怎么在Win7系统中清理系统日志
    怎么在Win7系统中清理系统日志?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。详细如下:右键点:我的电脑(计算机),再点:管理。点击:事件查看器,将其打开;点击:windo...
    99+
    2023-06-07
  • 如何在Docker中搭建FastDFS文件系统
    如何在Docker中搭建FastDFS文件系统?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。关于FastDFSFastDFS 是以 C 语言开发的一项开源轻量级...
    99+
    2023-06-15
  • 怎么在xp系统中搭建php
    本篇内容介绍了“怎么在xp系统中搭建php”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!步骤一:下载PHP在搭建PHP环境之前,您需要先下载...
    99+
    2023-07-05
  • 在Ubuntu系统中怎么清除Bash日志记录
    本篇内容主要讲解“在Ubuntu系统中怎么清除Bash日志记录”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“在Ubuntu系统中怎么清除Bash日志记录”吧! 在渗透测试中,要清除当前bash操...
    99+
    2023-06-13
  • 在Linux系统中怎么使用logwatch读取日志
    这篇文章主要介绍“在Linux系统中怎么使用logwatch读取日志”,在日常操作中,相信很多人在在Linux系统中怎么使用logwatch读取日志问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”在Linux系...
    99+
    2023-06-13
  • mongodb中怎么切割系统日志
    mongodb中怎么切割系统日志,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。    ...
    99+
    2024-04-02
  • Linux中怎么清除系统日志
    这期内容当中小编将会给大家带来有关Linux中怎么清除系统日志,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。#!/bin/sh cat /dev/null > ...
    99+
    2023-06-13
  • linux系统中怎么查看日志
    小编给大家分享一下linux系统中怎么查看日志,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!cattail -f日 志 文 件 说 明/var/log/messa...
    99+
    2023-06-16
  • Ubuntu中怎么查看系统日志
    在Ubuntu中,可以使用以下命令来查看系统日志: 查看系统日志文件: sudo cat /var/log/syslog 查...
    99+
    2024-03-05
    Ubuntu
  • centos7怎么搭建日志服务器
    在CentOS 7上搭建日志服务器可以使用Elasticsearch、Logstash和Kibana(ELK)组合来实现。下面是一个...
    99+
    2024-04-26
    centos7 服务器
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作