Prometheus+Grafana搭建日志采集

介绍

一、什么是日志数据采集

日志数据采集是指通过各种手段获取应用程序运行时产生的各类日志信息,并将这些信息存储到特定的地方,以便后续分析和使用。通常情况下,这些日志信息包括系统运行状态、错误信息、用户操作记录等等。通过对这些信息的统计和分析,可以有效地监控应用程序的运行状况,及时发现和解决问题。

二、为什么需要进行日志数据采集

对于企业应用系统而言,日志数据采集至关重要。首先,在应用程序出现问题时,通过查看相关日志信息可以快速定位原因,并进行相应处理。其次,在系统运行期间,通过对日志信息的统计和分析,可以发现系统存在的潜在问题,进而进行优化和改进。此外,对于一些业务场景,如在线广告、电商等,日志数据采集更是必不可少,它可以帮助企业更好地了解用户行为、偏好等信息,从而提升营销效果和用户体验。

三、常见的日志采集方案

在这里插入图片描述

方案介绍

• Promtail 是日志收集器,负责收集应用的日志并发送给 Loki。
• Loki 用于日志的存储和解析,并提供查询 API 给下游展示。
• Grafana 负责将 Loki 的日志可视化
在这里插入图片描述

Grafana搭建

之前写过,见文章:Prometheus+Grafana搭建

Loki安装

下载

https://github.com/grafana/loki/releases

#规划:安装在/usr/local下面,数据放在/data下
#以root账号,在/usr/local创建文件夹loki,并将安装包放置在此目录下
mkdir loki
#新建存储路径,数据放在/data下
mkdir  /data
mkdir  /data/loki
mkdir  /data/loki/{chunks,index}
#将安装包loki-linux-amd64.zip移动到/usr/local下,解压
unzip loki-linux-amd64.zip
#解压后重新生成文件夹loki-linux-amd64 ,将文件移动到loki目录下
mv loki-linux-amd64 /usr/local/loki/

在/usr/local/loki目录下,修改配置,如没有则新增
vi config.yaml

#在编辑页面可以插入下述脚本,可自行调整部分配置
auth_enabled: false
server:
  http_listen_port: 3100
ingester:
  lifecycler:
    address: xx.xx.xx.xx #ip地址
    ring:
      kvstore:
        store: inmemory
      replication_factor: 1
    final_sleep: 0s
  chunk_idle_period: 5m
  chunk_retain_period: 30s
 
schema_config:
  configs:
  - from: 2022-07-01
    store: boltdb
    object_store: filesystem
    schema: v11
    index:
      prefix: index_
      period: 168h   #每张表的时间范围7天
 
storage_config:
  boltdb:
    directory: /data/loki/index   #索引文件存储地址
 
  filesystem:
    directory: /data/loki/chunks  #块存储地址
 
limits_config:
  enforce_metric_name: false
  reject_old_samples: true
  reject_old_samples_max_age: 168h
chunk_store_config:
#最大可查询历史日期 28天,这个时间必须是schema_config中的period的倍数,否则报错。
  max_look_back_period: 672h
#表的保留期28天
table_manager:
  retention_deletes_enabled: true
  retention_period: 672h

#启动服务
nohup ./loki-linux-amd64 -config.file=./config.yaml >./loki.log 2>&1 &
#设置开机自启动
cd /etc/systemd/system/
vi loki.service

#可复制下述页面,调整文件路径即可
[Unit]
Description=loki
After=network.target 

[Service]
ExecStart=/usr/local/loki/loki-linux-amd64 \
        -config.file=/usr/local/loki/config.yaml &>> /usr/local/loki/loki.log
Restart=on-failure

[Install]
WantedBy=multi-user.target

设置自启动

systemctl daemon-reload

启动服务

systemctl start loki #systemctl stop loki systemctl restart loki

查看启动结果

systemctl status loki

加入开机自启动

systemctl enable loki

部署promtail

需要到日志采集端部署

下载

wget https://github.com/grafana/loki/releases/download/v2.8.0/promtail-linux-amd64.zip
#规划:安装在/usr/local下面
#以root账号,在/usr/local创建文件夹promtail,并将安装包放置在此目录下
mkdir promtail
#将安装包promtail-linux-amd64.zip移动到/usr/local下,解压
unzip promtail-linux-amd64.zip
#解压后重新生成文件夹promtail-linux-amd64 ,将文件移动到promtail目录下
mv promtail-linux-amd64  /usr/local/promtail/

在/usr/local/promtail目录下,修改配置,如没有则新增
vi promtail.yaml

#在编辑页面可以插入下述脚本,可自行调整部分配置
server:
  http_listen_port: 9080
  grpc_listen_port: 0
 
positions:
  filename: ./positions.yaml
 
clients:
  - url: http://xx.xx.xx.xx:3100/loki/api/v1/push   #loki地址,xx是ip地址
 
scrape_configs:
##jobname
 - job_name: centername                         #jobname
   static_configs:
   - targets: 
       - xx.xx.xx.xx                           #xx是ip地址
   - labels:
      job: centername                          #jobname
      host: xx.xx.xx.xx                        #xx是ip地址
      __path__: /home/script/log/*.log        #监控的日志地址,你们根据具体情况选择自己的路径

Promtail默认端口是9080,启动完成后,可以采用上边的方式查看进程是否启动成功

nohup ./promtail-linux-amd64 -config.file=promtail-local-config.yaml > promtail.log 2>&1 &

同样按照上面loki自启动的写法,也可以加入自启动中去

Grafana展示

模版导入

配置Loki数据源,导入监控模版 13639
在这里插入图片描述

<think>好的,我需要帮助用户了解如何使用PrometheusGrafana查看和分析监控数据。首先,我得回顾一下之前提供的引用内容,确保信息准确。 用户的问题集中在数据查看与分析,所以需要分步骤说明。首先应该提到Prometheus UI的基本使用,比如访问9090端口,然后介绍PromQL查询语言。比如up指标和内存、CPU的查询,这些在引用[2]里都有提到,需要正确引用。 接下来是Grafana的部分,需要说明如何配置数据源,导入仪表盘模板,比如Node Exporter的1860号模板。这部分在引用[1]和[2]里都有涉及,部署和可视化面板的搭建步骤需要简明扼要。 还要注意用户可能对PromQL不熟悉,需要举几个例子,比如计算内存使用率或者CPU负载。同时,要提到Grafana的图表类型和变量功能,这样用户知道如何自定义视图。 最后,常见问题部分应该包括数据延迟、语法错误和权限问题,这些都是用户可能会遇到的,引用中的BearerToken配置可能涉及到权限,需要适当提及。 整个过程中要确保使用正确的LaTeX格式,比如行内公式用$...$,独立公式用$$...$$。同时,生成的相关问题要围绕监控数据的查询、优化和故障排除,帮助用户深入理解。</think>以下是如何使用PrometheusGrafana查看与分析监控数据的完整步骤说明: ### 一、Prometheus数据查询 1. **访问Prometheus UI** 通过浏览器访问`http://<prometheus-server>:9090`,进入内置的可视化管理界面[^2] 2. **基础指标查询** - 服务存活检测:`up` 显示监控目标状态(1=正常,0=异常) 示例:`up{instance="localhost:8080"}` - 内存使用量:`node_memory_active_bytes/(1024^3)` 以GB显示活跃内存 公式:$$ \text{内存使用率} = \frac{node\_memory\_active\_bytes}{node\_memory\_MemTotal\_bytes} \times 100\% $$ - CPU负载:`node_load1` 显示1分钟平均负载[^2] 3. **高级查询技巧** - 使用`rate()`函数计算指标变化率: `rate(http_requests_total[5m])` - 多条件筛选: `http_requests_total{status="200",method="GET"}` ### 二、Grafana可视化分析 1. **数据源配置** 在Grafana中添加Prometheus数据源,填写URL:`http://prometheus:9090`[^1] 2. **仪表盘创建** - 新建Dashboard → Add panel - 选择图表类型(折线图/柱状图/仪表盘等) - 输入PromQL查询: ```sql sum by (instance) (rate(node_cpu_seconds_total{mode="idle"}[1m])) ``` 3. **模板化仪表盘(推荐)** 导入社区模板如Node Exporter Full(ID:1860),自动生成服务器监控面板[^2] ### 三、典型应用场景 1. **实时监控告警** 在Grafana设置Alert规则,如当`node_memory_available_bytes < 1GB`时触发通知 2. **性能趋势分析** 通过时间范围选择器对比不同时段的CPU负载: $$ \Delta Load = \frac{load_{current} - load_{baseline}}{load_{baseline}} \times 100\% $$ 3. **资源关联分析** 使用混合数据源将应用日志(Loki)与性能指标(Prometheus)关联展示 ### 常见问题排查 | 现象 | 检查点 | 解决方案 | |---------------------|-------------------------------|----------------------------| | 无数据显示 | 1. 数据源连接状态<br>2. 时间范围设置 | 检查Prometheus Target状态 | | 指标值异常 | 1. Exporter配置<br>2. 单位换算 | 验证/metrics端点数据准确性 | | 图表渲染错误 | 1. PromQL语法<br>2. 数据采样间隔 | 使用`Explain`功能调试查询 | ```bash # 验证Exporter数据采集(示例) curl http://exporter:9100/metrics | grep node_memory ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_三石_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值