详细分析 ▾
运行时依赖
版本
aliyun-sls-log-query技能的初始版本。使用查询|分析语法和Python SDK在阿里云日志服务(SLS)中启用日志查询和故障排查。提供设置说明、环境变量配置和Python快速入门示例。包括日志查询和故障排查工作流的脚本使用示例。记录关键工作流步骤、验证、输出标准和可复现性要求。链接了语法、SDK使用和故障排查模板的参考资料。
安装命令
点击复制技能文档
Category: service
# SLS日志查询和故障排查
使用SLS查询|分析语法和Python SDK进行日志搜索、过滤和分析。
前置条件
- 安装SDK(推荐使用虚拟环境以避免PEP 668限制):
python3 -m venv .venv
. .venv/bin/activate
python -m pip install -U aliyun-log-python-sdk
- 配置环境变量:
ALIBABA_CLOUD_ACCESS_KEY_ID
- ALIBABA_CLOUD_ACCESS_KEY_SECRET
- SLS_ENDPOINT(例如cn-hangzhou.log.aliyuncs.com)
- SLS_PROJECT
- SLS_LOGSTORE(支持单个值或逗号分隔的值)查询组合
- 查询子句:过滤日志(例如
status:500)。 - 分析子句:统计聚合,格式为
query|analysis。 - 示例:
| SELECT status, count() AS pv GROUP BY status
完整的语法请参阅references/query-syntax.md。
快速开始(Python SDK)
import os import time from aliyun.log import LogClient, GetLogsRequestclient = LogClient( os.environ["SLS_ENDPOINT"], os.environ["ALIBABA_CLOUD_ACCESS_KEY_ID"], os.environ["ALIBABA_CLOUD_ACCESS_KEY_SECRET"], )
project = os.environ["SLS_PROJECT"] logstore = os.environ["SLS_LOGSTORE"] query = "status:500"
start_time = int(time.time()) - 15 60 end_time = int(time.time())
request = GetLogsRequest(project, logstore, start_time, end_time, query=query) response = client.get_logs(request)
for log in response.get_logs(): print(log.contents)
脚本快速开始
python skills/observability/sls/aliyun-sls-log-query/scripts/query_logs.py \
--query "status:500" \
--last-minutes 15
可选参数:--project、--logstore(可重复,或逗号分隔的值)、--endpoint、--start、--end、--last-minutes、--limit、--parallel。
故障排查脚本
python skills/observability/sls/aliyun-sls-log-query/scripts/troubleshoot.py \
--group-field status \
--last-minutes 30 \
--limit 20
可选参数:--error-query、--group-field、--limit、--logstore(可重复,或逗号分隔的值)、--parallel,以及上述时间范围参数。
工作流
- 确保日志库索引已启用(没有索引,查询/分析将失败)。
- 编写查询子句并在需要时附加分析子句。
- 使用SDK/脚本执行并检查结果。
- 使用
limit控制返回的行数;必要时缩小时间范围。
验证
mkdir -p output/aliyun-sls-log-queryfor f in skills/observability/sls/aliyun-sls-log-query/scripts/.py; do python3 -m py_compile "$f" done
echo "py_compile_ok" > output/aliyun-sls-log-query/validate.txt
通过标准:命令退出0且生成output/aliyun-sls-log-query/validate.txt。
输出和证据
- 将工件、命令输出和API响应摘要保存在
output/aliyun-sls-log-query/下。 - 在证据文件中包含关键参数(区域/资源ID/时间范围)以确保可复现性。
参考资料
- 语法和示例:
references/query-syntax.md - Python SDK初始化和查询:
references/python-sdk.md - 故障排查模板:
references/templates.md - 源列表:
references/sources.md