Oracle数据库服务器CPU占用率巨高的问题排查思路

1、通过TOP 命令查看PID:

bash 复制代码
PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                                                         
 1560 oracle    20   0 38.978g 0.038t  16296 R 100.0 15.3   1069:13 python3 Main_Mem.py ProcessLog1 config.ini

2、通过spid 查找对应SQL:

sql 复制代码
-- 1、通过spid查找对应内存地址:
   SELECT addr FROM v$process c WHERE c.spid = 1560 ;

-- 2、通过内存地址寻址hash值:
   SELECT DECODE (sql_hash_value,
   0, prev_hash_value,
   sql_hash_value
   ),
   DECODE (sql_hash_value, 0, prev_sql_addr, sql_address)
   FROM v$session b
   WHERE b.paddr = '00000004B08F4DC8';

-- 3、通过hash值找到对应sql_id:
   select a.sql_text,a.sql_id From v$sqltext a where a.hash_value='3838526855' and a.address='00000004DBAE9638' order by piece;

-- 4、通过sql_id查找详细的sql查询脚本:
   select SQL_TEXT,SQL_FULLTEXT,SQL_ID,LOADS,FIRST_LOAD_TIME,PLSQL_EXEC_TIME,JAVA_EXEC_TIME,ROWS_PROCESSED,COMMAND_TYPE,PARSING_USER_ID,PARSING_SCHEMA_ID,PARSING_SCHEMA_NAME,KEPT_VERSIONS,ADDRESS,SERVICE,MODULE,MODULE_HASH,ACTION,CPU_TIME,ELAPSED_TIME,OUTLINE_SID,CHILD_ADDRESS,SQLTYPE,REMOTE,OBJECT_STATUS,LITERAL_HASH_VALUE,LAST_LOAD_TIME,PROGRAM_ID,PROGRAM_LINE#,LAST_ACTIVE_TIME
    from  v$sql where sql_id='{sqlID}'

3、查找到的sql主要分为三类:

1、where条件缺少主键;

2、where条件缺少索引;

3、对应主表数据量太大。

相关推荐
TDengine (老段)2 分钟前
TDengine 数据保留与 TTL — 多级存储、过期删除与分层迁移
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
安当加密03015 分钟前
等保2.0三级数据库加密:2026检查清单 + TDE部署实战(附脚本)
数据库·网络安全·数据安全·tde·等保2.0·数据库加密·tde透明加密
jingling5557 分钟前
Flutter | 从基本跳转到路由守卫
服务器·前端·网络·flutter·前端框架
解决问题no解决代码问题9 分钟前
TiDB 原理与节点宕机实战讲解
数据库·tidb
IOT.FIVE.NO.114 分钟前
Claude code+Vscode+Remote ssh+ 服务器自定义第三方API配置保姆级教程
服务器·vscode·ssh
饿了吃洗衣凝珠15 分钟前
【无标题】
运维·服务器·网络
江湖中的阿龙15 分钟前
Redis 五大核心数据类型底层原理
数据库·redis·缓存
染翰21 分钟前
Linux 配置:应用用户执行 sudo su root 免密(运维标准配置)
linux·运维·服务器
茫忙然31 分钟前
Claude Code 接入 DeepSeek 或 多模型 教程(Linux)
java·linux·数据库
wgc2k2 小时前
Node.js游戏服务器项目移植-2: 用TypeScript还是Javascript
服务器·游戏·node.js