安装测试环境:Ubuntu 16.04.2 LTS

前言

(1)ELK是Elasticsearch,Logstash,Kibana 开源软件的集合,对外是作为一个日志管理系统的开源方案。它可以从任何来源,任何格式进行日志搜索,分析获取数据,并实时进行展示。

(2)基本软件作用如下:

1、Filebeat:监控日志文件、转发,获取指定路径的日志文件,传输日志文件给Logstash;

2、Logstash: 日志收集,管理,存储,转发日志给Elasticsearch进行处理;

3、Elasticsearch:搜索,提供分布式全文搜索引擎,搜索是实时进行处理的,对数据进行索引和聚合等;

4、Kibana :日志的过滤web展示,图形界面话操作日志记录。别名Elasticsearch Dashboard
顾名思义是基于游览器的Elasticsearch分析和仪表盘工具;

(3)官网地址:https://www.elastic.co

(4)分支软件官方文档地址:

1、Logstash官方文档地址:https://www.elastic.co/guide/en/logstash/current/index.html

2、Filebeat官方文档地址:https://www.elastic.co/guide/en/beats/filebeat/current/index.html

3、Elasticsearch官方文档地址:https://www.elastic.co/guide/en/elasticsearch/reference/current/index.html

4、Kibana 官方文档地址:https://www.elastic.co/guide/en/kibana/current/index.html

ELK可用来干什么

ELK之间的架构关系

最简单的一个安装ELK的架构图如下:

以下是各数字代表箭头的含义:

(1)第1、2步代表使用FileBeat获取Tomcat服务器上的日志。当启动Filebeat时,它将启动一个或多个prospectors (检测者),查找Tomcat上指定的日志文件,作为日志的源头等待输出到Logstash。

(2)第3步代表Logstash从FileBeat获取日志文件。Filebeat作为Logstash的输入input将获取到的日志进行处理(FileBeat其实就是Logstash的一个输入插件beats,具体的处理过程后边学习),将处理好的日志文件输出到Elasticsearch进行处理。

(3)第4步代表Elasticsearch得到Logstash的数据之后进行相应的搜索存储操作。将写入的数据可以被检索和聚合等以便于搜索操作。

(4)第5代表Kibana 通过Elasticsearch提供的API将日志信息可视化的操作。

上述的1-5步骤中,我们可以看出一个Tomcat服务器产生的日志文件,如何由ELK系统获取,传输,处理,存储,可视化等操作的。

明白了ELK个软件的关系,那么安装起来就相对简单了很多,不会出现他们之间不知道具有什么关系的问题,下边就开始具体的安装过程。

Logstash安装与使用

Logstash官方文档地址:https://www.elastic.co/guide/en/logstash/current/index.html

根据上图中的架构图的话,应该是先安装FileBeat的,其实FileBeat只是Logstash的一个输入插件beats,Logstash具有很多输入插件,例如:标准输入插件stdin、文件输入插件file、syslog输入插件等等。

具体的Logstash输入插件可以参考官方文档:https://www.elastic.co/guide/en/logstash/current/input-plugins.html

既然,Logstash可以有多个输入插件,那么就使用最简单的方式进行Logstash的安装与验证工作。

一、Logstash安装

(1)确保JDK版本为1.8以上

(2)下载Logstash并解压

下载地址:https://www.elastic.co/downloads/logstash

选择红色框中版本!右键复制下载地址

这里为:https://artifacts.elastic.co/downloads/logstash/logstash-5.2.1.tar.gz

(3)使用wget下载:

(4)等待下载完成后解压:

使用tar -xvf logstash-5.1.1.tar.gz 命令解压文件,解压后使用cd命令进入文件夹内部:

主要文件夹包含bin、data、lib、config等。其中bin包含了一写可执行脚本文件,data是用于存储数据的,lib是一些系统所依赖的jar文件,config包含一些配置文件。

(5)要测试Logstash安装,运行最基本的Logstash管道:

cd logstash-5.1.1
bin/logstash -e 'input { stdin { } } output { stdout {} }'

-e 参数表示执行后边的语句,标志使您能够直接从命令行指定配置。在命令行中指定配置允许您快速测试配置,而无需在迭代之间编辑文件。示例中的管道从标准输入stdin获取输入,并以结构化格式将输入移动到标准输出stdout。

(6)等待片刻等提示信息之后,就可以在控制台输入任何内容,他都会输出:

至此,一个Logstash的安装与使用完成!

* 二、Logstash使用配置文件的方式运行*

上述,是通过命令行运行的,下边就是通过配置文件运行的一个完整的例子:

首先创建一个名为logstash.conf的配置文件放置在logstash-5.1.1目录下,内容就是刚才使用命令行方式的代码,如下:

然后在终端上运行:

bin/logstash -f logstash.conf

-f 表示指定使用哪一个配置文件进行执行。

* 三、Logstash基本原理*

Logstash管道有两个必需的元素,输入和输出,以及一个可选元素,过滤器。输入插件从源消耗数据,过滤器插件根据您指定的内容修改数据,输出插件将数据写入目标。如下图:

Logstash事件处理管道有三个阶段:输入→过滤器→输出。输入生成事件,过滤器修改它们,并将输出发送到其他地方。输入和输出支持编解码器,使您能够在数据进入或退出流水线时对其进行编码或解码,而无需使用单独的过滤器。也就是说,其实Logstash是一个input–decode –filter–encode–output的数据流!

使用Filebeat将日志行发送到Logstash

在创建Logstash管道之前,可以配置Filebeat以将日志行发送到Logstash。Filebeat客户端是一个轻量级的,资源友好的工具,他可以从服务器上的文件中收集日志,并将这些日志转发到Logstash实例进行处理。

Filebeat设计用于可靠性和低延迟。 Filebeat占用主机上轻量级的资源,Beats input插件可以最大限度地减少对Logstash实例的资源需求。

注意:

在实际的开发和生产环境中,Filebeat在运行Logstash实例机器的单独机器上运行。为了本教程的目的,Logstash和Filebeat在同一台机器上运行。

默认情况下Logstash安装的时候,已经包括Beats输入插件。Beats输入插件使Logstash能够从Elastic Beats框架中接收事件,这意味着任何写入Beat框架的Beat(如Packetbeat和Metricbeat)都可以将事件数据发送到Logstash。

一、下载安装Filebeat

由于新版本中已经默认安装了Filebeat插件,下边只是简要介绍:

(1)下载地址:https://www.elastic.co/downloads/beats/filebeat

(2)同样右键复制下载地址,通过wget下载:

(3)通过 tar -xvf filebeat-5.2.1-linux-x86_64.tar.gz 解压:

(4)修改配置文件将Tomcat服务器和Filebeat连接起来:

打开位于Filebeat安装目录中的filebeat.yml文件,修改需要检测的Tomcat服务器的文件位置:

其中:/home/xuliugen/www/ufind/logs/*.log 是我Tomcat服务器下项目的日志文件。并且已经开启了Tomcat。

(5)修改配置文件将Filebeat和Logstash连接起来:

同样是修改filebeat.yml文件,将output.elasticsearch注释掉,并打开Logstash的注释,修改之后内容如下:

保存更改。

(6)启动Filebeat

在数据源计算机上,使用以下命令运行Filebeat:

./filebeat -e -c filebeat.yml -d "publish"

Filebeat将尝试在端口5044上连接。直到Logstash探测到活动的Beats插件开始,该端口将不会有任何内容,因此,您看到的有关无法在该端口上连接的任何消息是正常的。

如果配置成功的话,就会去读取你指定的日志文件,如下:

(6)修改Logstash的配置文件

由于使用Filebeat作为输入,则需要修改相应的输入插件,修改前几步创建的logstash.conf文件,修改后的配置文件如下:

input {beats {port => "5044"}
}output {stdout {codec => rubydebug}
}

这里将beats(就是Filebeat)插件作为输入插件,端口号为5044,通过标准输出插件stdout 将数据显示在控制台中,其中stdout{} 里的codec => rubydebug 其中,rubydebug就是一种Codec,一般也只用在stdout插件中,作为配置测试或者调试的工具。

要验证您的配置,请运行以下命令:

bin/logstash -f logstash.conf --config.test_and_exit

--config.test_and_exit 选项将解析配置文件并报告任何出现错误的错误。

如果配置文件通过配置测试,请使用以下命令启动Logstash:

bin/logstash -f logstash.conf --config.reload.automatic

--config.reload.automatic 选项启用自动配置重新加载,这样的话你就不必在每次修改配置文件时停止和重新启动Logstash。

如果配置成功的话,如果你的Tomcat服务器有日志更新,在Logstash和Filebeat都会显示出来:

这个时候Filebeat也不会在报错,因为已经在5044端口和Logstash建立了连接。

第二篇

Linux操作系统安装ELK stack日志管理系统–(2)Elasticsearch与Kibana的安装与使用以及和Logstash的连接

Linux操作系统安装ELK stack日志管理系统--(1)Logstash和Filebeat的安装与使用相关推荐

  1. CentOS 7下安装Logstash ELK Stack 日志管理系统(上)

    介绍The Elastic Stack - 它不是一个软件,而是Elasticsearch,Logstash,Kibana 开源软件的集合,对外是作为一个日志管理系统的开源方案.它可以从任何来源,任何 ...

  2. linux操作系统安装自定义分区,CentOS linux操作系统安装图文教程

    目前linux操作系统安装方法非常多,我们可以通过一些常用的U盘启动盘工具制作对应的启动 U 盘后,然后再进行安装 Linux 系统即可.以下是今天给大家分享的 CentOS linux操作系统安装图 ...

  3. Linux操作系统安装LAMP环境

    本文给大家介绍的是在Linux操作系统安装LAMP环境的方法和步奏,十分的详细,有需要的小伙伴可以参考下. Step1. 安装 Apache 在terminal中输入命令 复制代码 代码如下:sudo ...

  4. Linux操作系统安装字体笔记

    从事Java程序员的朋友们都知道,大多数客户的应用都是部署在Linux操作系统的服务器上面,因为Linux服务器比Windows服务器成本要低.系统运行更加稳定.但它也有自己不足之处,比如在系统上导出 ...

  5. ubuntu系统虚拟机linux系统,基于虚拟机的Linux操作系统安装(Ubuntu

    <基于虚拟机的Linux操作系统安装(Ubuntu>由会员分享,可在线阅读,更多相关<基于虚拟机的Linux操作系统安装(Ubuntu(13页珍藏版)>请在人人文库网上搜索. ...

  6. dell4528s linux_戴尔电脑: 戴尔将力推预装Linux操作系统个人电脑!linux操作系统安装...

    [摘要] 据7月27日国外报道,一家提供Linux支持服务的公司的创始人表示,戴尔公司将会很快推出更多使用Linux操作系统的个人电脑,而不会使用微软的Windows操作系统.戴尔相信,开源软件爱好者 ...

  7. linux基础教程之Linux操作系统安装图文配置教程详细版

    这篇文章主要为大家详细介绍了Linux操作系统安装图文配置教程,帮助大家顺利的安装Linux操作系统,感兴趣的小伙伴们可以参考一下 随着嵌入式的发展,Linux的知识是必须的一部分,下面就让我们进行L ...

  8. Linux操作系统安装与使用(联想R720)

    Linux操作系统安装与使用 Linux操作系统安装 一.下载ubuntu镜像文件 下载ubuntu20.04 LTS 64位: http://releases.ubuntu.com/ 二.将镜像文件 ...

  9. 中南林业科技大学操作系统实验1-掌握Linux操作系统安装

    一.实验目的 掌握Linux操作系统的安装及基本操作 二.方法与步骤 1.准备好Linux镜像文件 2.设置好相关安装选项 3.设置账户密码 4.插入其他两张光盘 5.等待片刻,Linux操作系统安装 ...

  10. Linux操作系统安装及应用

    Linux操作系统安装 Linux系统简介     Linux是众多操作系统之一,是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 UNIX 的多用户.多任务.支持多线程和 ...

最新文章

  1. 线上讲座丨罗杰:前沿——NISQ时代下的工程超导量子计算机
  2. nacos 本地测试_一文详解 Nacos 高可用特性
  3. MFC获得主窗体和父窗体指针
  4. APICloud的config.xml应用配置的说明
  5. 【HTML5】Web前端——制作 3D 旋转魔方相册
  6. sonic云真机linux分布式部署
  7. 7.3.6 导航之激光雷达
  8. android车载行业前景,车载 Android 系统快来了,但前景可能并不乐观
  9. [转]c#对象的浅拷贝和深拷贝
  10. 网站优化怎样的外链能轻松收录,网站外链优化攻略
  11. LTE学习笔记-3 OFDM
  12. SecureCRT登录会话密码解密
  13. Java尚硅谷基础笔记-day4数组-数组常见算法
  14. 【干货】数据产品经理如何快速了解业务
  15. 如何系统性学习IT技术
  16. 秒懂设计模式之简单工厂模式(Simple Factory Pattern)
  17. linux下鼠标主题以及gtk主题,图标主题,字体的设置
  18. SAP-PP-标准工时与实际工时
  19. hilink互联技术_hilink是什么意思
  20. 基于golang的opencv人脸比对

热门文章

  1. 计算机算法基础总结(借鉴、整理)
  2. 2022G2电站锅炉司炉考试试题及答案
  3. C语言网络编程——基础
  4. 2022年Java面试题---中科创达
  5. 用AdobePageMaker制作PDF文档
  6. python处理卫星云图获取亮温值
  7. 子龙山人 opengl系列 - 网址
  8. Google 企业域名邮箱注册地址
  9. 解决LDAP客户端统一认证DirectoryEntry出现 Ox80005000的问题
  10. 虎牙服务器升级维护中 请留意公告,魔渊之刃像素危城系列活动上线-更新公告1月21日...