使用 Logstash 收集和处理 FastAPI 应用的日志

使用 Logstash 收集和处理 FastAPI 应用的日志

Logstash 是一个强大的数据处理管道,可以从多个来源收集数据,转换数据,并将其发送到存储系统中,如 Elasticsearch。以下是如何使用 Logstash 收集和处理 FastAPI 应用的日志的详细步骤。

什么是 Logstash?

Logstash 是一个开源的数据收集引擎,支持多种类型的输入数据,包括日志文件、系统消息队列、数据库等。它可以对数据进行各种转换和处理,然后将数据发送到各种目标,如 Elasticsearch、Kafka、邮件通知等

步骤 1:安装必要的包

首先,需要安装 python-logstash-async 包来异步发送日志:

csharp 复制代码
bash
pip install python-logstash-async

步骤 2:配置 FastAPI 应用

在你的 FastAPI 应用中,配置日志处理器以将日志发送到 Logstash。

python 复制代码
python
from fastapi import FastAPI, Request
from logstash_async.handler import AsynchronousLogstashHandler
import logging

app = FastAPI()

# 配置日志处理器
host = 'localhost'
port = 6000

logger = logging.getLogger("fastapi_logger")
logger.setLevel(logging.INFO)

async_handler = AsynchronousLogstashHandler(host, port, database_path=None)
logger.addHandler(async_handler)

# 定义一个中间件来捕获请求和响应日志
@app.middleware("http")
async def log_requests(request: Request, call_next):
    logger.info(f"Request: {request.method} {request.url}")
    
    response = await call_next(request)
    
    # 记录响应日志
    logger.info(f"Response: {response.status_code} {response.body}")
    
    return response

@app.get("/")
async def root():
    return {"message": "Hello World"}

步骤 3:配置 Logstash

在 Logstash 配置文件 (logstash.conf) 中,设置输入为 TCP,并指定 JSON 编解码器:

ini 复制代码
text
input {
  tcp {
    port => 6000
    codec => json
  }
}

output {
  elasticsearch {
    hosts => ["localhost:9200"]
    index => "fastapi_logs"
  }
}

步骤 4:运行 Logstash

启动 Logstash 服务:

复制代码
bash
logstash -f logstash.conf

步骤 5:运行 FastAPI 应用

启动你的 FastAPI 应用:

css 复制代码
bash
uvicorn main:app --reload

访问你的 FastAPI 应用时,响应日志将被发送到 Logstash,并存储在 Elasticsearch 中。通过 Kibana,你可以实时查看和分析这些日志。

优势

使用 python-logstash-async 包可以异步发送日志,这意味着你的应用不会因为日志发送而阻塞,从而提高了性能。同时,Logstash 的灵活配置可以帮助你处理和转换日志数据,以便更好地存储和分析。

示例代码和配置

  • FastAPI 应用配置:上述 Python 代码。
  • Logstash 配置 :上述 logstash.conf 文件内容。
  • 性能指标:异步日志发送可以提高应用性能,减少阻塞时间。

更多案例

  • 多源数据收集:Logstash 可以从多个来源(如日志文件、Redis、Kafka)收集数据。
  • 数据转换和过滤:使用 Logstash 的过滤器插件(如 Grok、JSON)对数据进行解析和转换。
  • 输出到多个目标:Logstash 支持输出到多个目标,如 Elasticsearch、Kafka、文件等。
相关推荐
十月南城9 分钟前
多级缓存设计思路——本地 + 远程的一致性策略、失效风暴与旁路缓存的取舍
后端
float_六七15 分钟前
Spring AOP连接点实战解析
java·后端·spring
武子康26 分钟前
大数据-183 Elasticsearch - 并发冲突与乐观锁、分布式数据一致性剖析
大数据·后端·elasticsearch
期待のcode43 分钟前
MyBatis-Plus的Wrapper核心体系
java·数据库·spring boot·后端·mybatis
老华带你飞1 小时前
出行旅游安排|基于springboot出行旅游安排系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring·旅游
舒一笑1 小时前
在低配云服务器上实现自动化部署:Drone CI + Gitee Webhook 的轻量级实践
前端·后端·程序员
李广坤1 小时前
Rust基本使用
后端·rust
我是你们的明哥1 小时前
Java优先级队列(PriorityQueue)详解:原理、用法与实战示例
后端·算法
是毛毛吧1 小时前
豆包风波后的破局者:智谱 AutoGLM 让“AI 手机”走向公共基建
人工智能·智能手机·开源·github·开源软件
Rendy_1 小时前
github copilot vscode插件 没有模型
vscode·github·copilot