Docker 部署 Grafana + Loki + Promtail 日志可视化搭建

1.Promtail配置文件

bash 复制代码
vim /data/promtail/promtail-config.yaml

server:
  http_listen_port: 9080
  grpc_listen_port: 0
positions:
  filename: /tmp/positions.yaml
clients:
  - url: http://host.docker.internal:3100/loki/api/v1/push
scrape_configs:
  - job_name: crm-logs
    static_configs:
      - targets:
          - localhost
        labels:
          job: "crm"
          __path__: /logs/*.log

2.启动 Loki

bash 复制代码
docker run -d --name loki -p 3100:3100 grafana/loki:latest

3、启动Grafana

bash 复制代码
docker run -d --name grafana -p 3000:3000 grafana/grafana:latest
bash 复制代码
http://localhost:3000
默认账号密码:
admin / admin

4.启动 Promtail

bash 复制代码
docker run -d --name promtail 
 -v /data/promtail/promtail-config.yaml:/etc/promtail/config.yml 
 -v /data/xxxxx/logs:/logs
 grafana/promtail:latest --config.file=/etc/promtail/config.yml

重要

验证 Promtail 状态:

bash 复制代码
docker logs promtail

如果看到:

tail routine: started

说明成功采集日志了

5.在 Grafana 接入 Loki

进入 Grafana:

导航:

Connections → Data sources → Add data source

选择:

Loki

URL 填:

bash 复制代码
http://host.docker.internal:3100

点击:

Save & test

6.日志查询语法(重点)

  1. Explore →Datasource 选择 Loki

    2.基础查询:
bash 复制代码
{job="crm"}
1)筛选错误日志
{job="crm"} |= "ERROR"
2)统计 ERROR 数量(支持图表)
sum(count_over_time({job="crm"} |= "ERROR" [1m]))
3)搜索关键字(如 cus)
{job="crm"} |= "cus"
相关推荐
星哥说事1 小时前
存储:PV / PVC / StorageClass 动态存储供给(K8s 存储核心篇)
云原生·容器·kubernetes
xiejava10181 小时前
企业级私有docker镜像仓库Harbor的搭建和使用
运维·docker·云原生·容器
YFLICKERH1 小时前
【Linux系统】Docker技术与应用
linux·docker
llc的足迹1 小时前
docker 中 gitlab 和 gitlab runner 离线安装及配置
docker·容器·gitlab
袁煦丞 cpolar内网穿透实验室1 小时前
Grafana突破局域网限制,随时随地访问数据看板! cpolar内网穿透实验室第 515 个成功挑战
grafana·远程工作·内网穿透·cpolar·随时访问
星哥说事2 小时前
容器编排:K8s 集群部署(kubeadm / kops)、节点管理全解读
云原生·容器·kubernetes
如果未来,11 小时前
k8s介绍,及其主要组件作用
云原生·容器·kubernetes
bendan5011 小时前
服务通过docker部署后,调用确定相互调用的URL
运维·docker·容器
阿拉斯攀登13 小时前
Kubernetes(K8s)全面解析:核心概念、架构与实践
docker·云原生·容器·kubernetes·k8s