linux服务之ELK

1 ELK的来源

        一般我们需要进行日志分析场景:直接在日志文件中 grep、awk 就可以获得自己想要的信息。但在规模较大的场景中,此方法效率低下,面临问题包括日志量太大如何归档、文本搜索太慢怎么办、如何多维度查询。需要集中化的日志管理,所有服务器上的日志收集汇总。常见解决思路是建立集中式日志收集系统,将所有节点上的日志统一收集,管理,访问。
        一般大型系统是一个分布式部署的架构,不同的服务模块部署在不同的服务器上,问题出现时,大部分情况需要根据问题暴露的关键信息,定位到具体的服务器和服务模块,构建一套集中式日志系统,可以提高定位问题的效率。

        一个完整的集中式日志系统,需要包含以下几个主要特点:

  • 收集-能够采集多种来源的日志数据;
  • 传输-能够稳定的把日志数据传输到中央系统;
  • 存储-如何存储日志数据;
  • 分析-可以支持 UI 分析;
  • 警告-能够提供错误报告,监控机制 ELK 提供了一整套解决方案,并且都是开源软件,之间互相配;
  • 合使用,完美衔接,高效的满足了很多场合的应用。目前主流的一种日志系统;

2 ELK简介

       ELK 是三个开源软件的缩写,分别表示:Elasticsearch , Logstash, Kibana , 它们都是开源软件。新增了一个 FileBeat,它是一个轻量级的日志收集处理工具(Agent),Filebeat 占用资源少,适合于在各个服务器上搜集日志后传输给 Logstash,官方也推荐此工具。

  • Elasticsearch 是个开源分布式搜索引擎,提供搜集、分析、存储数据三大功能。它的特点有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful 风格接口,多数据源,自动搜索负载等。
  • Logstash 主要是用来日志的搜集、分析、过滤日志的工具,支持大量的数据获取方式。一般工作方式为 c/s 架构,client 端安装在需要收集日志的主机上,server 端负责将收到的各节点日志进行过滤、修改等操作在一并发往 elasticsearch 上去。
  • Kibana 也是一个开源和免费的工具,Kibana 可以为 Logstash 和 ElasticSearch 提供的日志分析友好的 Web 界面,可以帮助汇总、分析和搜索重要数据日志。

       Filebeat 隶属于 Beats。目前 Beats 包含四种工具:

  • Packetbeat(搜集网络流量数据)
  • Topbeat(搜集系统、进程和文件系统级别的 CPU 和内存使用情况等数据)
  • Filebeat(搜集文件数据)
  • Winlogbeat(搜集 Windows 事件日志数据)

       整体的流程如下:

       

       如上,在客户端服务器上安装对应的Beats agent,beats agent可以直接将日志数据传给elasticsearch,也可以先传给logstash,再logstash传给elasticsearch。最后再通过kibana对elasticsearch的日志数据进行分析展示。

3 nginx监控部署举例

        本次部署的是 filebeats(客户端),logstash+elasticsearch+kibana(服务端)组成的架构。业务请求到达 nginx-server 机器上的 Nginx; Nginx 响应请求,并在 access.log 文件中增加访问记
录; FileBeat 搜集新增的日志,通过 LogStash 的 5044 端口上传日志; LogStash 将日志信息通过本机的 9200 端口传入到 ElasticSerach; 搜索日志的用户通过浏览器访问 Kibana,服务器端口是 5601;Kibana 通过 9200 端口访问 ElasticSerach。其流程如下图:

        

 

 

 

 

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
安装ELK(Elasticsearch,Logstash,Kibana)是一种常见的日志管理和可视化解决方案。以下是在Linux上使用Docker安装ELK的步骤: 1. 首先,使用Hi-elk镜像来快速搭建ELK服务。Hi-elk是一个基于Docker的镜像,专注于打造最简洁、最安全、最稳定的ELK镜像。它采用Alpine Linux系统作为底层。 2. 使用以下命令启动Kibana容器: ``` docker run -d -e ELASTICSEARCH_HOSTS='http://10.159.3.253:9200' -p 5601:5601 --name kibana kibana:7.6.0 ``` 这将在后台运行Kibana容器,并将其绑定到主机的5601端口,让您可以通过浏览器访问Kibana。 3. 如果在启动Kibana时遇到连接Elasticsearch的问题,可以尝试修改JVM内存参数。使用以下命令进入Kibana容器内部: ``` docker exec -it kibana /bin/bash ``` 在容器内部,可以编辑Kibana的配置文件,添加以下环境变量来修改JVM内存参数: ``` -e ES_JAVA_POTS="-Xms128m -Xmx128m" ``` 这将限制Kibana使用的JVM内存为128MB。 4. 如果您还需要启动Elasticsearch的可视化工具head,可以使用以下命令启动elasticsearch-head容器: ``` docker run --name elasticsearch-head -d -p 9100:9100 docker.io/mobz/elasticsearch-head:5 ``` 这将在后台运行elasticsearch-head容器,并将其绑定到主机的9100端口,让您可以通过浏览器访问elasticsearch-head。 通过按照上述步骤安装ELK,您将能够快速搭建一个基于Docker的ELK服务。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值