plg(Loki+Promtail+Grafana)监控nginx日志、messages日志监控平台

2023-11-30 02:20

本文主要是介绍plg(Loki+Promtail+Grafana)监控nginx日志、messages日志监控平台,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Loki 是一个水平可扩展,高可用性,多租户的日志聚合系统 。它的设计非常经济高效且易于操作,因为它不会为日志内容编制索引,而是为每个日志流编制一组标签。

Loki 组成:

    loki : 主服务器,负责存储日志和处理查询

    promtail : 代理,负责收集日志并将其发送给 loki

    Grafana : Go语言开发的开源数据可视化工具,可以做数据监控和数据统计,带有告警功能

登录官网:loki官网Like Prometheus, but for logs. Contribute to grafana/loki development by creating an account on GitHub.https://github.com/grafana/loki/releases/

一、loki安装配置

1.1 环境准备

----root用户操作
###创建用户
useradd loki
passwd loki###创建安装目录
mkdir /opt/loki###授权
chown -R loki:loki /opt/loki
chmod -R 755 /opt/loki----loki用户操作
###下载二进制包
$ curl -O -L "https://github.com/grafana/loki/releases/download/v2.7.4/loki-linux-amd64.zip"###解压二进制包
$ unzip "loki-linux-amd64.zip"### make sure it is executable
$ chmod a+x "loki-linux-amd64"

1.2 编写配置文件

$ vim loki-local-config.yml

更多配置请参考:https://grafana.com/docs/loki/latest/configuration/

auth_enabled: falseserver:http_listen_port: 3100grpc_listen_port: 9096ingester:lifecycler:address: 127.0.0.1ring:kvstore:store: inmemoryreplication_factor: 1final_sleep: 0schunk_idle_period: 10mchunk_retain_period: 30s
schema_config:configs:- from: 2020-05-15store: boltdbobject_store: filesystemschema: v11index:prefix: index_period: 168h
storage_config:boltdb:directory: /opt/loki/indexfilesystem:directory: /opt/loki/chunks  # 块存储路径limits_config:enforce_metric_name: falsereject_old_samples: true          # 是否拒绝老样本reject_old_samples_max_age: 168h  # 168小时之前的样本将会被删除ingestion_rate_mb: 200ingestion_burst_size_mb: 300per_stream_rate_limit: 1000MBmax_entries_limit_per_query: 10000
chunk_store_config:max_look_back_period: 168h        # 为避免查询超过保留期的数据,必须小于或等于下方的时间值
table_manager:retention_deletes_enabled: true   # 保留删除开启retention_period: 168h            # 超过168h的块数据将被删除ruler:storage:type: locallocal:directory: /opt/loki/rulesrule_path: /opt/loki/rules-tempalertmanager_url: http://192.168.0.1:9093    # alertmanager地址ring:kvstore:store: inmemoryenable_api: trueenable_alertmanager_v2: true

1.3 编写启动脚本

$ vim restart-loki.sh

#!/bin/bash
echo "stop loki"
ps -ef | grep loki-linux-amd64 | grep -v grep | awk '{print $2}'| xargs kill -9 echo "Begin start loki"
sleep 1
str=$"\n"
nohup ./loki-linux-amd64 --config.file=loki-local-config.yml &
sstr=$(echo -e $str)
echo $sstr

1.4 增加执行权限

$chmod +x restart-loki.sh

1.5 loki的启动

cd /opt/loki
./restart-loki.sh

1.6 loki日志查看

[root@localhost loki]# tail -10f nohup.out 
level=info ts=2023-03-26T08:40:48.324631438Z caller=checkpoint.go:614 msg="starting checkpoint"
level=info ts=2023-03-26T08:40:48.324805699Z caller=checkpoint.go:339 msg="attempting checkpoint for" dir=wal/checkpoint.000022
level=info ts=2023-03-26T08:45:18.327347566Z caller=checkpoint.go:501 msg="atomic checkpoint finished" old=wal/checkpoint.000022.tmp new=wal/checkpoint.000022
level=info ts=2023-03-26T08:45:18.32797424Z caller=checkpoint.go:572 msg="checkpoint done" time=4m30.002891425s
level=info ts=2023-03-26T08:45:48.325049331Z caller=checkpoint.go:614 msg="starting checkpoint"
level=info ts=2023-03-26T08:45:48.32524561Z caller=checkpoint.go:339 msg="attempting checkpoint for" dir=wal/checkpoint.000023
level=info ts=2023-03-26T08:50:18.327325742Z caller=checkpoint.go:501 msg="atomic checkpoint finished" old=wal/checkpoint.000023.tmp new=wal/checkpoint.000023
level=info ts=2023-03-26T08:50:18.327880793Z caller=checkpoint.go:572 msg="checkpoint done" time=4m30.002463306s
level=info ts=2023-03-26T08:50:48.325234397Z caller=checkpoint.go:614 msg="starting checkpoint"
level=info ts=2023-03-26T08:50:48.325402194Z caller=checkpoint.go:339 msg="attempting checkpoint for" dir=wal/checkpoint.000024

二、日志代理Promtail安装和配置

负责收集日志并将其发送给 loki,在需要采集日志的主机上都安装Promtail

2.1 Promtail环境准备

mkdir /opt/promtail
chown -R loki:loki /opt/promtail
chmod -R loki:loki /opt/promtail###下载
curl -O -L "https://github.com/grafana/loki/releases/download/v2.7.4/promtail-linux-amd64.zip"###解压
unzip loki-linux-amd64.zip # 解压

2.2 编写Promtail配置文件

vim promtail-local-config.yml

server:http_listen_port: 9080grpc_listen_port: 0positions:filename: /opt/promtail/positions.yamlclients:- url: http://10.X.X.125:3100/loki/api/v1/push # 填写好Loki地址scrape_configs:
- job_name: messagelogstatic_configs:- targets:- localhostlabels:#job: messageloghost: namenode01__path__: /var/log/messages- job_name: agentlogstatic_configs:- targets:- localhostlabels:#job: agentloghost: namenode01__path__: /ssd/ssd0/agentlog/agent.log- job_name: datanodelogstatic_configs:- targets:- localhostlabels:
#      #job: datanodeloghost: namenode01__path__: /ssd/ssd0/datanodelog/*datanode*.log

2.3 编写promtail启动脚本

vi restart-promtail.sh

#!/bin/bash
echo "Begin stop promtail"
ps -ef | grep promtail-linux-amd64 | grep -v grep | awk '{print $2}' | xargs kill -9echo "Begin start promtail...."
nohup ./promtail-linux-amd64 --config.file=promtail-local-config.yml > ./promtail-9080.log 2>&1 &

2.4 增加执行权限

$chmod +x restart-promtail.sh

2.5 启动promtail服务

[root@localhost promtail]# cd /opt/promtail[root@localhost promtail]# ./restart-promtail.sh 
Begin stop promtail
Begin start promtail....
[root@localhost promtail]# 

三、 Grafana可视化安装和配置

    Grafana : Go语言开发的开源数据可视化工具,可以做数据监控和数据统计,带有告警功能

3.1 Grafana安装配置

Download Grafana | Grafana LabsOverview of how to download and install different versions of Grafana on different operating systems.https://grafana.com/grafana/download

###CentOS系统通过rpm方式安装wget https://dl.grafana.com/enterprise/release/grafana-enterprise-9.4.3-1.x86_64.rpmsudo yum install grafana-enterprise-9.4.3-1.x86_64.rpm -y[root@localhost grafana]# rpm -qa|grep grafana
grafana-enterprise-9.4.3-1.x86_64
[root@localhost grafana]# 

3.2 启动grafana

grafana会占用服务器3000端口

##启动
systemctl start grafana-server.service##停止
systemctl stop grafana-server.service##重启
systemctl restart grafana-server.service##设置开机自启动
systemctl enable grafana-server.service##状态查看
systemctl status grafana-server.service

3.3 grafana导入nginx dashboard

Grafana Loki Dashboard for NGINX Service Mesh | Grafana LabsLoki v2+ showcase using JSON NGINX access logs.https://grafana.com/grafana/dashboards/12559-grafana-loki-dashboard-for-nginx-service-mesh/

3.4 grafana配置告警邮箱

编辑Grafana配置文件,设置发件人
docker安装的Grafana:vim /home/monitor/grafana/config/grafana.ini
yum安装:vim /etc/grafana/grafana.ini

在[smtp] 标签下 修改配置

# 配置邮件服务器
[smtp]
enabled = true# 发件服务器
host = smtp.mail.139.com:465# smtp 密码
password = PAASmail2019# smtp账号
user = paas-support@139.com# 发信邮箱
from_address = paas-support@139.com# 发信人
from_name = Grafana

保存好配置文件之后,重启Grafana

##重启
systemctl restart grafana-server.service

3.5 测试grafana告警发送

点击页面左边的铃铛,并选择 Contact points

然后选择 Add contact point 创建一个 contact point,填写 Name 和收件人邮箱地址

然后点击Test ,提示成功后,刚填写的邮箱应该就可以收到如下内容的测试邮件 

查看邮箱,成功收到邮件


 

参考:简易日志系统LPG生产环境实践指南 | 坑我已经帮你们踩好了

参考:PLG日志平台搭建: Promtail + Loki + Grafana 全步骤_promtail loki_dxccccccccccc的博客-CSDN博客

参考:Promtail + Loki + Grafana 构建日志监控告警系统(一)_promtail+loki_5D金豆豆的博客-CSDN博客

参考:

PLG日志平台搭建: Promtail + Loki + Grafana 全步骤_promtail loki_dxccccccccccc的博客-CSDN博客

参考:

搭建Loki、Promtail、Grafana轻量级日志系统(centos7)_loki promtail_成钰的博客-CSDN博客

参考:

轻量日志收集系统loki_loki日志收集_wyl9527的博客-CSDN博客

参考:

轻量级日志可视化平台Grafana Loki接入nginx访问日志-阿里云开发者社区

参考:

PLG 云原生日志系统在压测中的落地实践 · TesterHome

参考:

快速部署Grafana日志监控+Nginx封禁IP-阿里云开发者社区

参考:

使用使用grafana中文插件-阿里云开发者社区

这篇关于plg(Loki+Promtail+Grafana)监控nginx日志、messages日志监控平台的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/435250

相关文章

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

Linux之platform平台设备驱动详解

《Linux之platform平台设备驱动详解》Linux设备驱动模型中,Platform总线作为虚拟总线统一管理无物理总线依赖的嵌入式设备,通过platform_driver和platform_de... 目录platform驱动注册platform设备注册设备树Platform驱动和设备的关系总结在 l

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)