
高效将SLS日志导入MongoDB数据库
在容器化环境中,Serverless Log Service (SLS) 扮演着重要的日志收集角色。本文将指导您如何自动将SLS收集的JSON格式日志导入MongoDB数据库。
解决方案
由于SLS不支持直接导出到MongoDB,我们需要借助脚本实现日志导入。以下方案利用脚本定期从SLS下载日志,再写入MongoDB。
操作步骤
-
Python脚本准备
创建一个名为
write2mongo.py的Python脚本:
新视窗CMS企业管理程序 5.1下载新视窗企业管理系统是一款小巧、实用、利于后续开发的ASP程序。适合大中小型企业的网站建设。1、新闻管理 2、产品管理 3、订单管理 4、广告管理 5、下载管理 6、留言管理 8、单页栏目(如企业简介,资质荣誉)9、人才招聘等等。 新视窗企业管理系统 5.1 更新日志:1、修改产品列表的图片自动缩略,防止图片变形.2、修改后台添加产品分类时,排序ID不写入数据库的错误.3、修改首页企业简介的链接地址
import pymongo import subprocess as sh import json import time client = pymongo.MongoClient("mongodb://: ") db = client[" "] collection = db[" "] while True: # 获取SLS日志 logs = sh.check_output(["aliyunlog", "log", "get_all_log", " "]).decode("utf-8") # 解析并写入MongoDB for log in logs.splitlines(): if log: try: collection.insert_one(json.loads(log)) except json.JSONDecodeError: print(f"Skipping invalid JSON: {log}") # 设定执行间隔 (1.5秒) time.sleep(1.5) 请替换以下占位符:
-
: MongoDB数据库IP地址 -
: MongoDB数据库端口 -
: MongoDB数据库名称 -
: MongoDB集合名称 -
: SLS项目名称
-
-
脚本运行
在服务器或容器中运行以下命令:
aliyunlog log get_all_log
| python write2mongo.py
重要提示
- 确保已创建MongoDB数据库和集合。
- 脚本需要具备读取SLS日志的权限。
- 可根据实际需求调整日志下载和写入频率。 错误处理已添加到脚本中,以跳过无效的JSON数据。 建议使用
check_output代替run来更好地处理命令执行错误。
通过以上步骤,您可以实现SLS日志的自动化导入,方便后续的日志分析和处理。









