使用Loggie将FastAPI Web日志上传到阿里云SLS的简单教程

本教程将指导你如何在Ubuntu系统上使用Loggie将FastAPI的Web日志上传到阿里云SLS。我们将一步步地完成安装、配置和测试。

步骤1:安装Loggie

1. 安装Golang

首先,确保你的Ubuntu系统上已经安装了Golang。如果尚未安装,可以使用以下命令:

bash 复制代码
sudo apt update
sudo apt install -y golang-go

2. 下载Loggie源码

你可以从GitHub下载Loggie的源码:

bash 复制代码
git clone https://github.com/loggie-io/loggie.git
cd loggie

3. 编译Loggie

如果你下载了源码,需要编译Loggie:

bash 复制代码
go build -o loggie main.go

4. 配置环境变量(可选)

如果你想全局使用Loggie,可以配置环境变量:

bash 复制代码
export PATH=$PATH:/path/to/loggie

步骤2:配置阿里云SLS

1. 创建阿里云SLS Project和Logstore

  • 登录阿里云控制台,进入SLS控制台。
  • 创建一个新的Project和Logstore。

2. 获取AccessKey ID和AccessKey Secret

  • 创建一个RAM用户,并授予该用户对Project和Logstore的写入权限。
  • 获取RAM用户的AccessKey ID和AccessKey Secret。

步骤3:配置Loggie

1. 创建Loggie配置文件

创建一个名为pipelines.yml的配置文件,内容如下:

yaml 复制代码
pipelines:
- name: web-logs
  sources:
  - type: file
    name: web-logs
    paths:
    - /path/to/your/web/logs/*.log
    addonMeta: true
  sink:
    type: sls
    endpoint: ${endpoint}  # 阿里云SLS服务入口
    accessKeyId: ${accessKeyId}
    accessKeySecret: ${accessKeySecret}
    project: ${project}     # 你的Project名称
    logstore: ${logstore}   # 你的Logstore名称
    topic: myweblogs        # 自定义日志主题

2. 设置环境变量

在终端中设置环境变量:

bash 复制代码
export endpoint="cn-shanghai.log.aliyuncs.com"
export accessKeyId="YOUR_ACCESS_KEY_ID"
export accessKeySecret="YOUR_ACCESS_KEY_SECRET"
export project="YOUR_PROJECT_NAME"
export logstore="YOUR_LOGSTORE_NAME"

步骤4:运行Loggie

1. 启动Loggie服务

使用以下命令启动Loggie:

bash 复制代码
./loggie --config.path=pipelines.yml

2. 确保Loggie持续运行

可以使用systemdsupervisord等工具来管理Loggie服务。

步骤5:测试日志上传

1. 生成测试日志

确保你的FastAPI应用正在生成日志,并且日志文件位于配置的路径中。

2. 检查SLS日志

登录阿里云SLS控制台,进入你的Logstore查看是否成功上传了日志。

示例代码:FastAPI生成日志

如果你使用FastAPI,可能需要配置日志输出到文件。以下是一个简单的示例:

python 复制代码
from fastapi import FastAPI
from logging.handlers import RotatingFileHandler
import logging

app = FastAPI()

# 配置日志
logger = logging.getLogger(__name__)
logger.setLevel(logging.INFO)

# 创建文件处理器
file_handler = RotatingFileHandler('/path/to/your/web/logs/app.log', maxBytes=1024*1024*10, backupCount=5)
file_handler.setLevel(logging.INFO)

# 创建格式器
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
file_handler.setFormatter(formatter)

# 添加处理器
logger.addHandler(file_handler)

@app.get("/")
def read_root():
    logger.info("访问根路径")
    return {"Hello": "World"}

通过这些步骤,你应该能够成功地使用Loggie将FastAPI的Web日志上传到阿里云SLS中。

相关推荐
猫头虎24 分钟前
2026最新|GitHub 启用双因素身份验证 2FA 教程:TOTP.app 一键生成动态验证码(新手小白图文实操)
git·开源·gitlab·github·开源软件·开源协议·gitcode
开心就好202524 分钟前
iOS Crash日志全面解析:结构、类型与分析方法
后端
毕设源码-钟学长30 分钟前
【开题答辩全过程】以 基于Spring Boot的社区养老服务管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
nbsaas-boot36 分钟前
slice / map 在 Go GC 与内存碎片上的真实成本
开发语言·后端·golang
数据小馒头40 分钟前
拒绝循环写库:MySQL 批量插入、Upsert 与跨表更新的高效写法
后端
子洋43 分钟前
基于远程开发的大型前端项目实践
运维·前端·后端
indexsunny1 小时前
互联网大厂Java面试实战:微服务、Spring Boot与Kafka在电商场景中的应用
java·spring boot·微服务·面试·kafka·电商
sheji34161 小时前
【开题答辩全过程】以 基于spring boot的停车管理系统为例,包含答辩的问题和答案
java·spring boot·后端
源代码•宸1 小时前
Leetcode—1266. 访问所有点的最小时间【简单】
开发语言·后端·算法·leetcode·职场和发展·golang
爱学英语的程序员2 小时前
让AI 帮我做了个个人博客(附提示词!)
人工智能·git·vue·github·node·个人博客