Grafana Loki LogMonitor采集日志

Grafana Loki LogMonitor采集日志

1.采集架构图

null

image-20250830095509362

2.部署loki服务器

ruby 复制代码
# 准备文件夹
root@ubuntu2204-98:~# cd /usr/local/prometheus_monitor/
root@ubuntu2204-98:/usr/local/prometheus_monitor# mkdir loki/{config,data_loki}
root@ubuntu2204-98:/usr/local/prometheus_monitor# mkdir -p  loki/{config,data_loki}
root@ubuntu2204-98:/usr/local/prometheus_monitor# ls loki/
config  data_loki
root@ubuntu2204-98:/usr/local/prometheus_monitor# cd loki/config/
root@ubuntu2204-98:/usr/local/prometheus_monitor/loki# chmod -R 777 *
root@ubuntu2204-98:/usr/local/prometheus_monitor/loki/config# 
# 下载配置文件到config配置文件(一般不用修改,可以根据自己需要进行修正)
wget https://raw.githubusercontent.com/grafana/loki/v3.4.1/cmd/loki/loki-local-config.yaml -O loki-config.yaml

# 这里我修改了loki-config.yaml中alertmanager_url地址
ruler:
  alertmanager_url: http://192.168.1.98:9093

# 准备docker-compose文件
root@ubuntu2204-98:/usr/local/prometheus_monitor/loki# vi docker-compose.yml
services:
  loki:
    container_name: loki
    image: grafana/loki:main-04f8929
    command: "-config.file=/etc/loki/config.yaml"
    ports:
      - "9096:9096"
      - "3100:3100"
    volumes:
      - ./config/loki-config.yaml:/etc/loki/config.yaml:ro
      - ./data_loki:/loki:rw
    restart: unless-stopped

# 启动并查看状态
root@ubuntu2204-98:/usr/local/prometheus_monitor/loki# docker-compose up -d
root@ubuntu2204-98:/usr/local/prometheus_monitor/loki# docker-compose ps
NAME                IMAGE                       COMMAND                  SERVICE             CREATED             STATUS              PORTS
loki                grafana/loki:main-04f8929   "/usr/bin/loki -conf..."   loki                9 seconds ago       Up 8 seconds        0.0.0.0:3100->3100/tcp, :::3100->3100/tcp, 0.0.0.0:9096->9096/tcp, :::9096->9096/tcp

3.Grafana添加loki数据源

null

image-20250830102428603

null

image-20250830102458798

null

image-20250830102542094

4.监控端部署并接入系统日志

ruby 复制代码
# 创建目录
root@ubuntu2204-98:/usr/local/prometheus_monitor# mkdir -p promtail/config
root@ubuntu2204-98:/usr/local/prometheus_monitor# chmod -R 777 promtail/*
# 创建配置文件,因为我只是复现之前工作中的内容所以都在一台机器上,如果你是实际部署记得修改相关配置
root@ubuntu2204-98:/usr/local/prometheus_monitor# cd promtail/
root@ubuntu2204-98:/usr/local/prometheus_monitor/promtail# vi config/promtail-config.yaml
server:
  http_listen_port: 9080
  grpc_listen_port: 0

positions:
  filename: /tmp/positions.yaml

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

scrape_configs:
- job_name: system
  static_configs:
  - targets:
      - 192.168.1.98
    labels:
      job: servlogs
      __path__: /var/log/*log
# 创建docker-compose文件
root@ubuntu2204-98:/usr/local/prometheus_monitor/promtail# vi docker-compose.yml 
services:
  promtail:
    image: grafana/promtail:main-04f8929
    container_name: promtail
    volumes:
      - /usr/local/prometheus_monitor/promtail/config:/mnt/config
      - /var/log:/var/log
    command: -config.file=/mnt/config/promtail-config.yaml

4.1 ssh日志模板 17514

null

image-20250830102822991

4.2 系统日志模板 13639

null

image-20250830103127506

5.接入Docker容器日志监控

css 复制代码
# 这里是对单独容器的监控,也就是你在启动其他容器的时候也要单独设置
# 被监控端的Docker安装插件
root@ubuntu2204-98:~/n8n# docker plugin install grafana/loki-docker-driver:latest --alias loki
Plugin "grafana/loki-docker-driver:latest" is requesting the following privileges:
 - network: [host]
Do you grant the above permissions? [y/N] y
latest: Pulling from grafana/loki-docker-driver
Digest: sha256:82270b494d8c157f035fde65bc0159076f4c4361b5bb061b4fc817e8db04234a
32dbe5a742d5: Complete 
Installed plugin grafana/loki-docker-driver:latest

# 安装后启动一个docker应用来测试下,启动的时候要指定日志服务器参数
# docker-compose文件
services:
  n8n:
    image: n8nio/n8n
    container_name: n8n
    # 这里指定了日志服务器位置
    logging:
      driver: loki
      options:
        loki-url: "http://192.168.1.98:3100/loki/api/v1/push"
        loki-retries: 2
        loki-max-backoff: 800ms
        loki-timeout: 1s
        keep-file: "true"
        mode: "non-blocking"

5.1 容器日志查看

null

image-20250830105210635

6.结束语

到这里大概日志收集的方法都已经展示了,实验环境是无所谓规划一类的东西,在实际生产中大家如果要部署,一定要根据自己公司实际情况,对于主机硬件配置、收集信息内容等进行合理规划,不然你上了监控可能会让你自己更加混乱,切记切记~~~~!

相关推荐
JustHappy3 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
Hommy883 小时前
【剪映小助手】添加图片接口(Add Images)
后端·github·剪映小助手·视频剪辑自动化
GetcharZp4 小时前
别再盲目用 OpenCV 读图了,这才是 CV 预处理的终极杀手锏!
后端
IT_陈寒7 小时前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端
椰椰椰耶8 小时前
[SpringCloud][14]OpenFeign参数传递方法
后端·spring·spring cloud
onething3659 小时前
Spring Boot + Spring AI 从入门到实战:7天转型计划 Day 3 —— 消息表设计 + 级联删除 + 事务管理
人工智能·后端
荣江9 小时前
Hermes Agent 代码仓库打包工具使用指南(repomix-rs 高性能版)
后端
王某某人9 小时前
LangChain4j 入门:Java 程序员的第一个 AI 对话程序
人工智能·后端
码农刚子9 小时前
从零开始:在 Windows 服务器上部署 Node.js 项目(小白实战教程)
后端·node.js
Cache技术分享9 小时前
435. Java 日期时间 API - Clock 灵活获取当前时间
前端·后端