PolarDB-X 1.0-用户指南-SQL审计与分析-日志分析

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
简介: PolarDB-X支持SQL审计与分析功能,依托日志服务产品,提供强大的日志分析能力。本文档将介绍常见场景的SQL日志分析语句及示例。

背景信息

开启PolarDB-X SQL审计与分析功能之后,您可以在当前页面通过日志服务的查询分析语法进行SQL 审计与分析。结合日志服务的查询分析语法,在日志分析页面,您可以快速定位问题 SQL,并针对PolarDB-X数据库的SQL执行状况、性能指标,安全问题进行分析。关于日志服务的查询分析语法,详情请参见查询语法分析概述

注意事项

相同Region下,PolarDB-X数据库的审计日志都是写入同一个日志服务的Logstore里,所以PolarDB-X SQL审计与分析的搜索页面会默认为您带上按照__topic__的过滤条件,保证您搜索到的SQL日志是PolarDB-X数据库的。因此本文提供的所有的查询语句,都需要在已有的过滤条件后追加使用。

例如下图中序号1部分的语句为默认过滤条件,序号2部分的语句为追加的过滤条件。

p128020.png

快速定位问题SQL

您可以使用以下命令快速定位问题SQL。

  • 模糊搜索例如,您可以使用如下命令查询包含关键字为34的SQL语句:
and sql: 34
  • 查询结果如下图所示:p130034.pngp128023.png
  • 字段搜索依赖预置的索引字段,PolarDB-X SQL审计还支持根据字段搜索。例如您可以使用如下命令查询Drop类型的SQL:
and sql_type:Drop
  • 查询结果如下图所示:
    日志服务支持鼠标点击自动生成查询语句,如下图所示。p143313.png
  • 多条件搜索您可以通过andor等关键字实现多条件的搜索。例如您可以使用如下命令查询对id=34行的删除操作:
and sql:34 and sql_type: Delete
  • 数值比较搜索索引字段中的affect_rowsresponse_time是数值类型,支持比较操作符。例如您可以使用如下命令查询response_time大于1s的Insert SQL:
and response_time  > 1507 and sql_type: Insert
  • 或者使用如下命令查询删除100行以上数据的SQL:
and affect_rows  > 100 and sql_type: Delete

SQL执行状况分析

您可以使用以下命令查看SQL执行状况。

  • SQL执行失败率您可以使用以下命令查询SQL执行的失败率:
| SELECT sum(case when fail = 1 then 1 else 0 end) * 1.0 / count(1) as fail_ratio
  • 查询结果如下图所示:
    p161722.png如果您的业务对SQL错误率敏感,可以在此查询结果的基础上,定制报警信息,单击下图中1所示的另存为告警。以下报警设置表示每隔15分钟,检查15分钟内SQL执行的错误率大于0.01的日志数量。您也可以根据业务需要定制告警。p161723.png
  • SQL累计查询行数您可以使用如下命令查询Select语句累计查询的行数:
and sql_type: Select | SELECT sum(affect_rows)
  • SQL类型分布您可以使用如下命令查询SQL类型分步:
| SELECT  sql_type, count(sql) as times GROUP BY sql_type
  • SQL独立用户 IP 分布您可以使用如下命令查询SQL独立用户的IP地址分布:
| SELECT  user, client_ip, count(sql) as times GROUP BY user, client_ip

SQL性能分析

您可以使用以下命令查看SQL性能分析详情。

  • SELECT平均耗时您可以使用以下命令查询SELECT语句的平均耗时:
and sql_type: Select | SELECT avg(response_time)
  • SQL执行耗时分布您可以使用以下命令查询SQL执行耗时分布。
and response_time > 0 | select   case  when response_time <= 10 then '<=10毫秒'  when response_time > 10 and response_time <= 100 then '10~100毫秒'  when response_time > 100 and response_time <= 1000 then '100毫秒~1秒'  when response_time > 1000 and response_time <= 10000  then '1秒~10秒'  when response_time > 10000 and response_time <= 60000  then '10秒~1分钟'  else '>1分钟' end as latency_type,  count(1) as cnt group by latency_type order by latency_type DESC

  • 说明 上述查询给出了按照给定时间段的SQL执行时间分布,您也可以调整时间段的范围,获取更加精细的结果。
  • 慢SQL Top 50您可以使用以下命令查询系统排名前50的慢SQL
| SELECT date_format(from_unixtime(__time__), '%m/%d %H:%i:%s') as time, user, client_ip, client_port, sql_type, affect_rows, response_time, sql ORDER BY  response_time desc LIMIT 50
  • 查询结果如下图所示,结果中包含SQL执行时间、执行的用户名、IP 地址、端口号、SQL 类型、影响行数、执行时间以及SQL的文本。p161724 (1).png
  • 高代价SQL模板Top 10在大多数应用中,SQL通常基于若干模板动态生成的,只是参数不同。您可以使用以下命令通过模板ID找到应用中高代价的SQL模板进行分析优化:
| SELECT sql_code as "SQL模板ID", round(total_time * 1.0 /sum(total_time) over() * 100, 2) as "总体耗时比例(%)" ,execute_times as "执行次数", round(avg_time) as "平均执行时间",round(avg_rows) as "平均影响行数", CASE WHEN length(sql) > 200 THEN  concat(substr(sql, 1, 200), '......') ELSE trim(lpad(sql, 200, ' ')) end as "样例SQL" FROM  (SELECT sql_code, count(1) as execute_times, sum(response_time) as total_time, avg(response_time) as avg_time, avg(affect_rows) as avg_rows, arbitrary(sql) as sql FROM log GROUP BY sql_code) ORDER BY "总体耗时比例(%)" desc limit 10
  • 统计结果包括SQL模板ID,该模板SQL占总体SQL的耗时比例、执行次数、平均执行时间、平均影响行数以及样例 SQL(为了显示效果,该列按照200的长度截断)。
    p161724.png
    说明 上述查询是按照总体耗时比例排序,当然您也可以根据平均执行时间,执行次数进行排序排查问题。
  • 事务平均执行时长对于相同事务内的SQL,预置的trace_id字段前缀相同,后缀为'-' + 序号;非事务的SQL的trace_id中则不包含'-'。因此,您可以使用如下命令对事务SQL的性能进行相关分析。说明由于事务分析涉及前缀匹配操作,查询效率会低于其它类型的查询操作。
  • 查询事务的平均执行耗时:
| SELECT  sum(response_time) / COUNT(DISTINCT substr(trace_id, 1, strpos(trace_id, '-') - 1)) where strpos(trace_id, '-') > 0
  • 慢事务Top 10可以按照事务的执行时间排序查询慢事务的列表:
| SELECT substr(trace_id, 1, strpos(trace_id, '-') - 1) as "事务ID" , sum(response_time) as "事务耗时" where strpos(trace_id, '-') > 0 GROUP BY substr(trace_id, 1, strpos(trace_id, '-') - 1) ORDER BY "事务耗时" DESC LIMIT 10
  • 在此基础上,可以根据查到的慢事务ID,搜索该事务下的所有SQL,分析执行慢的具体原因,查询语句如下:
and trace_id: db3226a20402000*
  • 大批量操作事务Top 10按照事务内SQL影响的行数,可以获取大批量操作的事务列表,查询语句如下:
| SELECT substr(trace_id, 1, strpos(trace_id, '-') - 1) as  "事务ID" , sum(affect_rows) as "影响行数" where strpos(trace_id, '-') > 0 GROUP BY substr(trace_id, 1, strpos(trace_id, '-') - 1) ORDER BY "影响行数" DESC LIMIT 10

SQL安全性分析

您可以使用以下命令查看SQL安全性分析情况。

  • 错误SQL类型分布您可以使用如下命令查看错误SQL类型分布:
and fail > 0 | select sql_type, count(1) as "错误次数" group by sql_type
  • 高危SQL列表高危SQL是指DROP或RUNCATE类型的SQL,您也可以根据需求增加更多条件。
and sql_type: Drop OR  sql_type: Truncate
  • 大批量删除SQL列表您可以使用如下命令大批量删除SQL列表:
and affect_rows > 100 and sql_type: Delete | SELECT date_format(from_unixtime(__time__), '%m/%d %H:%i:%s') as time, user, client_ip, client_port, affect_rows, sql ORDER BY  affect_rows desc LIMIT 50
相关实践学习
快速体验PolarDB开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
相关文章
|
29天前
|
SQL 存储 缓存
日志服务 SQL 引擎全新升级
SQL 作为 SLS 基础功能,每天承载了用户大量日志数据的分析请求,既有小数据量的快速查询(如告警、即席查询等);也有上万亿数据规模的报表级分析。SLS 作为 Serverless 服务,除了要满足不同用户的各类需求,还要兼顾性能、隔离性、稳定性等要求。过去一年多的时间,SLS SQL 团队做了大量的工作,对 SQL 引擎进行了全新升级,SQL 的执行性能、隔离性等方面都有了大幅的提升。
|
1月前
|
SQL 存储 缓存
MySQL进阶突击系列(02)一条更新SQL执行过程 | 讲透undoLog、redoLog、binLog日志三宝
本文详细介绍了MySQL中update SQL执行过程涉及的undoLog、redoLog和binLog三种日志的作用及其工作原理,包括它们如何确保数据的一致性和完整性,以及在事务提交过程中各自的角色。同时,文章还探讨了这些日志在故障恢复中的重要性,强调了合理配置相关参数对于提高系统稳定性的必要性。
|
3月前
|
SQL 数据库
为什么 SQL 日志文件很大,我应该如何处理?
为什么 SQL 日志文件很大,我应该如何处理?
|
3月前
|
SQL 存储 数据可视化
手机短信SQL分析技巧与方法
在手机短信应用中,SQL分析扮演着至关重要的角色
|
4月前
|
SQL 存储 缓存
高基数 GroupBy 在 SLS SQL 中的查询加速
本文详细介绍了SLS中的高基数GroupBy查询加速技术。
156 22
|
3月前
|
SQL 数据库
为什么SQL日志文件很大,该如何处理?
为什么SQL日志文件很大,该如何处理?
|
4月前
|
SQL 安全 数据库
基于SQL Server事务日志的数据库恢复技术及实战代码详解
基于事务日志的数据库恢复技术是SQL Server中一个非常强大的功能,它能够帮助数据库管理员在数据丢失或损坏的情况下,有效地恢复数据。通过定期备份数据库和事务日志,并在需要时按照正确的步骤恢复,可以最大限度地减少数据丢失的风险。需要注意的是,恢复数据是一个需要谨慎操作的过程,建议在执行恢复操作之前,详细了解相关的操作步骤和注意事项,以确保数据的安全和完整。
230 0
|
5月前
|
数据库 Java 监控
Struts 2 日志管理化身神秘魔法师,洞察应用运行乾坤,演绎奇幻篇章!
【8月更文挑战第31天】在软件开发中,了解应用运行状况至关重要。日志管理作为 Struts 2 应用的关键组件,记录着每个动作和决策,如同监控摄像头,帮助我们迅速定位问题、分析性能和使用情况,为优化提供依据。Struts 2 支持多种日志框架(如 Log4j、Logback),便于配置日志级别、格式和输出位置。通过在 Action 类中添加日志记录,我们能在开发过程中获取详细信息,及时发现并解决问题。合理配置日志不仅有助于调试,还能分析用户行为,提升应用性能和稳定性。
72 0
|
8月前
|
安全 druid Java
Seata 1.8.0 正式发布,支持达梦和 PolarDB-X 数据库
Seata 1.8.0 正式发布,支持达梦和 PolarDB-X 数据库
663 11
Seata 1.8.0 正式发布,支持达梦和 PolarDB-X 数据库
|
8月前
|
存储 DataWorks 监控
DataWorks,一个 polar db 有上万个数据库,解决方案
DataWorks,一个 polar db 有上万个数据库,解决方案

相关产品

  • 云原生分布式数据库 PolarDB-X