Loki+Promtail+Grafana监控K8s日志

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 综上,Loki+Promtail+Grafana 监控组合对于在 K8s 环境中优化日志管理至关重要,它不仅提供了强大且易于扩展的日志收集与汇总工具,还有可视化这些日志的能力。通过有效地使用这套工具,可以显著地提高对应用的运维监控能力和故障诊断效率。

在现代云原生架构中,监控与日志管理对于确保系统稳定性和可靠性至关重要。Kubernetes(K8s)作为当下流行的容器编排平台,对日志的监控管理需求尤为突出。Loki, Promtail 和 Grafana 构成了一套强大的日志监控解决方案,它们协同工作提供了高效的日志采集、存储和可视化功能。

Loki 是一个水平可扩展、高可用性、多租户的日志聚合系统,它被设计用来优雅地与 Grafana 协同工作。Promtail 则是一个日志收集工具,专门用来获取日志并发送到 Loki。Grafana 是一个开放的可视化平台,可以用来绘制时间序列数据的图表、可视化仪表板等。

监控K8s日志的步骤通常包括以下几个方面:

Step 1: 配置并部署 Loki

部署 Loki 可以通过 Kubernetes manifests 或 Helm charts 进行。Helm 是一个 K8s 的包管理工具,它能简化安装和管理 K8s 应用的过程。

Step 2: 配置并部署 Promtail

Once Loki is up and running, the next step is to deploy Promtail on all K8s nodes. Promtail must be configured to discover and scrape log files, parsing and sending them to Loki. Configuration involves defining job entries to tell Promtail which log files to scrape, employing a combination of service discovery and static targets.

Step 3: 搭建 Grafana 并与 Loki 集成

部署 Grafana 在同一个 K8s 集群,并配置 Grafana 去查询 Loki 托管的日志。Grafana 提供了专门的 Loki 数据源插件,方便用户集成并开始查询和可视化日志数据。

实战代码演示

部署 Loki

使用 Helm 部署 Loki 的一种简单命令可能是:

helm install loki grafana/loki-stack

配置 Promtail

Promtail 的配置可以由 Kubernetes ConfigMap 来管理,以下是一个基本的配置示例:

apiVersion: v1
kind: ConfigMap
metadata:
  name: promtail-config
  labels:
    name: promtail
data:
  promtail.yaml: |
    server:
      http_listen_port: 9080
      grpc_listen_port: 0

    positions:
      filename: /tmp/positions.yaml

    clients:
      - url: http://loki:3100/loki/api/v1/push

    scrape_configs:
    - job_name: kubernetes-pods
      kubernetes_sd_configs:
      - role: pod

      relabel_configs:
      - source_labels: [__meta_kubernetes_pod_node_name]
        target_label: __host__

在 Grafana 配置 Loki 数据源

在 Grafana 的界面,需要添加一个新的数据源,选择 Loki 作为类型,并填写 Loki 服务的 URL。

查询和可视化日志

在 Grafana 中创建新的 Dashboard,并配置 Panels 以使用 Loki 数据源进行日志查询。查询可以简单如 {app="your-app-name"}, 这会返回所有标签为 app: your-app-name 的日志条目。

综上,Loki+Promtail+Grafana 监控组合对于在 K8s 环境中优化日志管理至关重要,它不仅提供了强大且易于扩展的日志收集与汇总工具,还有可视化这些日志的能力。通过有效地使用这套工具,可以显著地提高对应用的运维监控能力和故障诊断效率。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
3月前
|
Kubernetes Ubuntu Windows
【Azure K8S | AKS】分享从AKS集群的Node中查看日志的方法(/var/log)
【Azure K8S | AKS】分享从AKS集群的Node中查看日志的方法(/var/log)
117 3
|
2月前
|
Kubernetes API Docker
跟着iLogtail学习容器运行时与K8s下日志采集方案
iLogtail 作为开源可观测数据采集器,对 Kubernetes 环境下日志采集有着非常好的支持,本文跟随 iLogtail 的脚步,了解容器运行时与 K8s 下日志数据采集原理。
|
3月前
|
消息中间件 Kubernetes API
在K8S中,如何收集k8s集群日志?
在K8S中,如何收集k8s集群日志?
|
3月前
|
消息中间件 Kubernetes Kafka
微服务从代码到k8s部署应有尽有系列(十一、日志收集)
微服务从代码到k8s部署应有尽有系列(十一、日志收集)
|
3月前
|
Kubernetes Shell 网络安全
【Azure K8S】记录AKS VMSS实例日志收集方式
【Azure K8S】记录AKS VMSS实例日志收集方式
|
3月前
|
存储 Prometheus Kubernetes
在K8S中,如何收集K8S日志?有哪些方案?
在K8S中,如何收集K8S日志?有哪些方案?
|
3月前
|
存储 Kubernetes 数据可视化
在K8S中,如何使用 EFK 实现日志的统一管理?
在K8S中,如何使用 EFK 实现日志的统一管理?
|
3月前
|
Kubernetes API Docker
在K8S中,如何查看kubelet组件的日志?
在K8S中,如何查看kubelet组件的日志?
|
3月前
|
Kubernetes 容器 Perl
在K8S中,如何查看Pod中某个容器日志?
在K8S中,如何查看Pod中某个容器日志?
|
3月前
|
Kubernetes API 容器
在k8S中,使用kubectl logs无法查看日志是什么原因,如何让其能够查看?
在k8S中,使用kubectl logs无法查看日志是什么原因,如何让其能够查看?