- 浏览: 469429 次
- 性别:
- 来自: 青岛
文章分类
最新评论
-
此去经年雪123:
为啥生成的是乱码 你好
关于使用JS前台加密、JAVA后台解密的RSA实现,RSA加密和签名 -
alonglw:
zxf0089216 写道1.为什么每次都是10001RSAK ...
关于使用JS前台加密、JAVA后台解密的RSA实现,RSA加密和签名 -
zxf0089216:
1.为什么每次都是10001RSAKeyPair(" ...
关于使用JS前台加密、JAVA后台解密的RSA实现,RSA加密和签名 -
dunhanson:
后台的测试main方法都能加密解密。前台加密后的密文交给后台解 ...
关于使用JS前台加密、JAVA后台解密的RSA实现,RSA加密和签名 -
map612:
wula0010 写道仔细看了下,可以运行RSAUtil.ma ...
关于使用JS前台加密、JAVA后台解密的RSA实现,RSA加密和签名
解决oracle10g运行慢、无法确定瓶颈的问题,为了找到效率低的sql费劲不少,今天找到一个,
方法就是查看awr报告。
Oracle 在10g以前的使用的是 Statspack做性能故障诊断的。Oracle Database 10g 提供了一个显著改进的工具:自动工作负载信息库 (AWR)。
Oracle 建议用户用这个取代 Statspack。AWR 实质上是一个 Oracle 的内置工具,和数据库一起安装。
数据库装好后,快照由一个称为 MMON 的新的后台进程及其从进程自动地每小时采集一次(snap)
它采集与性能相关的统计数据,并从那些统计数据中导出性能量度,以跟踪潜在的问题。
为了节省空间,采集的数据在 7 天后自动清除。快照频率和保留时间都可以由用户修改。它产生两种类型的输出:文本格式(类似于 Statspack
报表的文本格式但来自于 AWR 信息库)和默认的 HTML 格式(拥有到部分和子部分的所有超链接),从而提供了非常用户友好的报表。
AWR 使用几个表来存储采集的统计数据,所有的表都存储在新的名称为 SYSAUX 的特定表空间中的 SYS 模式下,并且以 WRM$_* 和
WRH$_* 的格式命名,H 代表“历史数据 (historical)”而 M 代表“元数据 (metadata)”。
前一种类型(WRM$_*)存储元数据信息(如检查的数据库和采集的快照),
后一种类型(WRH$_*)保存实际采集的统计数据。
在这些表上构建了几种带前缀 DBA_HIST_ 的视图,这些视图可以用来编写您自己的性能诊断工具。
视图的名称直接与表相关;例如,视图 DBA_HIST_SYSMETRIC_SUMMARY 是在WRH$_SYSMETRIC_SUMMARY 表上构建的。
select t.view_name from dba_views t where t.view_name like 'DBA_HIST%'
AWR 历史表采集的信息比 Statspack 多许多,这些信息包括表空间使用率、文件系统使用率、甚至操作系统统计数据。
具体操作方式:
登陆到服务器的操作系统;
进入到$ORACLE_HOME/rdbms/admin目录下;
然后sqlplus "/as sysdba"登陆到数据库,执行
@awrrpt.sql;
然后按照提示一步一步做,注意格式选html(这样方便你阅读)。
过程中需要设置以下值:
report_type=html或text,enter采用默认为html
num_days=1
begin_snap=输入开始快照ID
end_snap=输入结束快照ID
report_name=输入要保存的文件名,enter采用默认文件名
Oracle默认1个小时产生一次快照,可以查看、修改这个频率,可以手工创建、删除快照。
完了之后,你把那个文件拷贝到本地用IE打开就看到了。里面有很详细的,包括这段时间占CPU,IO,等等最严重的SQL排行。比如“SQL ordered by Elapsed Time”列出耗费时间最长的sql。
==============一些资料=======================
1.查看当前的AWR保存策略、设置:快照间隔、保存时间。
SQL> col SNAP_INTERVAL format a20
SQL> col RETENTION format a20
SQL> select * from dba_hist_wr_control;
DBID SNAP_INTERVAL RETENTION TOPNSQL
---------- -------------------- -------------------- ----------
262089084 +00000 01:00:00.0 +00007 00:00:00.0 DEFAULT
以上结果表示,每小时产生一个SNAPSHOT,保留7天。
2.调整AWR配置,修改快照间隔和保存时间等。
AWR配置都是通过dbms_workload_repository包进行配置。
2.1 调整AWR产生snapshot的频率和保留策略,
如将收集间隔时间改为30 分钟一次。并且保留5天时间(单位都是分钟):
SQL> exec dbms_workload_repository.modify_snapshot_settings(interval=>30, retention=>5*24*60);
设置快照时间间隔为 20 分钟,保留时间为两天 -- 您可以发出以下命令。参数以分钟为单位。
SQL> exec dbms_workload_repository.modify_snapshot_settings ( interval => 20, retention => 2*24*60 );
2.2 关闭AWR,把interval设为0则关闭自动捕捉快照
SQL> exec dbms_workload_repository.modify_snapshot_settings(interval=>0);
2.3 手工创建一个快照
SQL> exec DBMS_WORKLOAD_REPOSITORY.CREATE_SNAPSHOT();
exec dbms_workload_repository.create_snapshot;
2.4 查看快照
SQL> select * from sys.wrh$_active_session_history
SQL> select count(*),max(snap_id) from wrh$_active_session_history;
2.5 手工删除指定范围的快照
SQL> exec DBMS_WORKLOAD_REPOSITORY.DROP_SNAPSHOT_RANGE(low_snap_id => 973, high_snap_id => 999, dbid => 262089084);
2.6 创建baseline,保存这些数据用于将来分析和比较
SQL> exec dbms_workload_repository.create_baseline(start_snap_id => 1003, end_snap_id => 1013, 'apply_interest_1');
2.7 删除baseline
SQL> exec DBMS_WORKLOAD_REPOSITORY.DROP_BASELINE(baseline_name => 'apply_interest_1', cascade => FALSE);
2.8 将AWR数据导出并迁移到其它数据库以便于以后分析
SQL> exec DBMS_SWRF_INTERNAL.AWR_EXTRACT(dmpfile => 'awr_data.dmp', mpdir => 'DIR_BDUMP', bid => 1003, eid => 1013);
2.9 迁移AWR数据文件到其他数据库
SQL> exec DBMS_SWRF_INTERNAL.AWR_LOAD(SCHNAME => 'AWR_TEST', dmpfile => 'awr_data.dmp', dmpdir => 'DIR_BDUMP');
把AWR数据转移到SYS模式中:
SQL> exec DBMS_SWRF_INTERNAL.MOVE_TO_AWR (SCHNAME => 'TEST');
3.AWR报告日常分析
3.1 SQL ordered by Elapsed Time
记录了执行总和时间的TOP SQL(请注意是监控范围内该SQL的执行时间总和,而不是单次SQL执行时间 Elapsed Time = CPU Time + Wait Time)。
Elapsed Time(S): SQL语句执行用总时长,此排序就是按照这个字段进行的。注意该时间不是单个SQL跑的时间,而是监控范围内SQL执行次数的总和时间。单位时间为秒。Elapsed Time = CPU Time + Wait Time
CPU Time(s): 为SQL语句执行时CPU占用时间总时长,此时间会小于等于Elapsed Time时间。单位时间为秒。
Executions: SQL语句在监控范围内的执行次数总计。
Elap per Exec(s): 执行一次SQL的平均时间。单位时间为秒。
% Total DB Time: 为SQL的Elapsed Time时间占数据库总时间的百分比。
SQL ID: SQL语句的ID编号,点击之后就能导航到下边的SQL详细列表中,点击IE的返回可以回到当前SQL ID的地方。
SQL Module: 显示该SQL是用什么方式连接到数据库执行的,如果是用SQL*Plus或者PL/SQL链接上来的那基本上都是有人在调试程序。一般用前台应用链接过来执行的sql该位置为空。
SQL Text: 简单的sql提示,详细的需要点击SQL ID。
3.2 SQL ordered by CPU Time:
记录了执行占CPU时间总和时间最长的TOP SQL(请注意是监控范围内该SQL的执行占CPU时间总和,而不是单次SQL执行时间)。
3.3 SQL ordered by Gets:
记录了执行占总buffer gets(逻辑IO)的TOP SQL(请注意是监控范围内该SQL的执行占Gets总和,而不是单次SQL执行所占的Gets)。
3.4 SQL ordered by Reads:
记录了执行占总磁盘物理读(物理IO)的TOP SQL(请注意是监控范围内该SQL的执行占磁盘物理读总和,而不是单次SQL执行所占的磁盘物理读)。
3.5 SQL ordered by Executions:
记录了按照SQL的执行次数排序的TOP SQL。该排序可以看出监控范围内的SQL执行次数。
3.6 SQL ordered by Parse Calls:
记录了SQL的软解析次数的TOP SQL。说到软解析(soft prase)和硬解析(hard prase)见:http://www.taoyoyo.net/ttt/post/305.html
3.7 SQL ordered by Sharable Memory:
记录了SQL占用library cache的大小的TOP SQL。Sharable Mem (b):占用library cache的大小,单位是byte。
3.8 SQL ordered by Version Count:
记录了SQL的打开子游标的TOP SQL。
3.9 SQL ordered by Cluster Wait Time:
记录了集群的等待时间的TOP SQL
发表评论
-
Oracle 百万行数据查询优化
2011-08-31 13:16 15311.对查询进行优化, ... -
【转载】ORACLE误删数据的恢复
2011-03-18 22:29 1753一、利用SCN恢复 ... -
利用数据库将字符串分割成Table函数
2011-03-14 15:54 16211、Oracle中 创建代码: create or rep ... -
Oracle、SqlServer、MySql临时表小结
2011-01-22 12:04 25031、Oracle临时表 Oracle临时表分为两种 ... -
[转]Oracle的JDBC驱动的版本你了解吗?
2010-11-17 15:31 1043在使用Oracle JDBC驱动时,有些问题你是 ... -
(转)Oracle中PFILE和SPFILE的使用
2010-10-28 08:50 2567在9i以前,Oracle使用pfile存储初 ... -
关于Oracle10.2.0自行启动两个监听进程导致服务中断问题
2010-09-01 16:12 3188环境: AIX6.1 Oracle Database ... -
笔记:查看Oracle表空间使用率的sql
2010-07-14 17:41 1967SELECT UPPER(F.TABLESPACE ... -
Oracle中如何使用DBLink连接不同的实例
2010-05-22 10:06 4445实际生产过程中,通常会遇到不同数据库之间进行数据交换的问题,有 ... -
Oracle10g只有数据文件的恢复方式
2010-03-22 14:42 2389待完成。 1、首先安装一个全新的ORACLE,包 ... -
一个Oracle分页的存储过程
2010-02-03 16:54 1462Oracle下通用的分页脚本: CREATE OR R ... -
Oracle用户锁定/解锁
2009-12-28 09:40 3267解锁/锁定命令 ALTER USER ECODE ACCOU ... -
如何查看Oracle某时刻的客户端连接情况并显示客户端IP
2009-12-18 15:18 139621、查看每个oracle帐 ... -
Oracle存储过程中使用临时表
2009-12-18 08:51 13444一、Oracle临时表知识 在O ... -
深入浅出理解索引结构
2009-10-24 20:31 891深入浅出理 ... -
ORACLE单行函数
2009-10-24 09:15 1881可以作下列事情: 描述SQL中 ... -
Oracle修改存储空间相关sql
2009-09-23 11:23 14541、查看表空间情况: ... -
Linux下Oracle10g不能启动之 could not open parameter file
2009-08-19 18:00 5930今天开发服务器突然连接不上,sqlplus /nolog、co ... -
Oracle的分区管理
2009-06-12 15:53 1044一、 分区概述: 为了简化数据库大表的管理,ORA ... -
Oracle创建索引 小贴士
2009-06-12 15:46 2716索引( Index )是常见的数 ...
相关推荐
在Oracle数据库管理中,了解SQL语句的执行性能和频率对于系统优化至关重要。本文将详细介绍如何查看Oracle数据库中执行最慢和查询次数最多的SQL语句,以帮助DBA(数据库管理员)识别潜在的性能瓶颈。 首先,我们来...
4. **历史记录**:存储SQL语句的历史执行信息,便于追踪性能变化趋势和问题的演变过程。 5. **对比分析**:比较不同时间段或不同版本的SQL执行性能,帮助识别性能提升或下降的原因。 6. **优化建议**:根据SQL语句...
7. **历史记录**: 除了实时监控,Oracle SQL语句监视器还记录了过去一段时间内的SQL活动,便于进行趋势分析和问题回溯。 在实际应用中,Oracle SQL语句监视器可以通过以下方式使用: - **调试**: 当遇到性能问题时...
总结来说,获取Oracle SQL语句的执行时间可以采用`SET TIMING ON`实时显示或者查询`V$SQL`视图来查看历史记录。前者适用于临时测试和调试,后者则更适合长期监控和性能分析。了解和掌握这两种方法,对于优化数据库...
当SQL语句执行效率低下时,可能导致数据库响应时间延长,服务器负载增加,甚至影响整个应用程序的性能。因此,SQL优化对于保持系统的高效运行至关重要。 SQL优化工具通常提供以下功能: 1. **查询分析**:这些工具...
用户可以创建批处理作业,设置定时执行,自动化日常维护任务,甚至可以监控执行状态和历史记录。 总的来说,Oracle SQL批处理是数据库管理员和开发人员不可或缺的工具,它简化了大量重复性工作,提高了工作效率,...
在Oracle数据库管理中,有时我们需要将SQL查询的结果集导出为文本文件,或者保存执行的SQL语句以供后续使用或记录。Oracle提供了一些实用的命令来实现这些功能,主要涉及`spool`和`sav`(或者`savelist`)这两个命令...
Oracle SQL Monitor是一款强大的数据库性能监控工具,主要用于跟踪和分析Oracle数据库中的SQL语句执行情况。在数据库管理和优化中,理解SQL语句的执行性能是至关重要的,因为这直接影响到数据库的响应时间和整体效率...
这款工具在Oracle数据库环境中扮演着重要角色,它可以帮助用户实时监控SQL语句的执行情况,识别性能瓶颈,从而提高系统的整体效率。 在描述中提到,SQLTracker可以在Windows 11操作系统上直接运行,这意味着它可能...
它不仅记录SQL语句的历史执行信息,还能分析出SQL的执行计划,帮助识别是否存在索引不当、全表扫描等问题。此外,通过对比不同时间段的性能数据,可以找出数据库性能变化的原因,为性能调优提供决策依据。 再者,...
在实际应用中,使用“生成SQL语句工具”不仅可以提高开发效率,还能确保SQL语句的准确性和可维护性。对于大型项目或团队协作,这类工具尤其重要,因为它们能保证所有团队成员遵循一致的编码规范和最佳实践。 总的来...
SQLMONITOR是一款强大的数据库监控工具,它专门设计用于实时监控Oracle、MySQL和DB2数据库中正在执行的SQL语句。这个工具对于数据库管理员和开发人员来说极其重要,因为它可以帮助他们诊断性能问题,优化查询,以及...
6. **SQL Profile和SQL Plan Baseline**:Oracle 10g引入了SQL Profile,11g引入了SQL Plan Baseline,它们可以根据历史执行情况为SQL语句生成最佳执行计划,避免因数据分布改变导致的性能下降。 7. **绑定变量和...
同时,它可能还提供性能分析,通过优化查询结构和建议使用索引等方式,提升SQL语句的执行效率。对于大型数据库应用来说,这一点至关重要,因为一个优化的SQL语句可以显著降低服务器负载,提高系统响应速度。 在...
在Oracle数据库管理中,SQL跟踪是一项至关重要的功能,它允许管理员监控数据库的性能,找出执行效率低下或者占用资源过多的SQL语句,从而进行优化。SQLTracker就是这样一款工具,它能够帮助我们有效地实现这一目标。...
1. **SQL语句捕获**:记录数据库系统执行的所有SQL语句,无论是来自应用程序还是直接通过数据库客户端。 2. **性能分析**:分析捕获到的SQL语句,提供查询执行时间、资源消耗等信息,帮助用户识别性能瓶颈。 3. **...
1. **计划历史记录**(Plan History):对于执行超过一次的SQL语句,优化器会记录其每一次的执行计划及其相关信息,如SQL文本、绑定变量等,形成执行计划的历史记录。 2. **执行计划基准线**(Plan Baseline):这是...
在使用SecureCRT进行远程连接到数据库时,特别是通过SQL*Plus工具执行SQL语句时,我们可能会遇到一个问题:使用上下箭头键来翻阅之前输入过的SQL命令时,SecureCRT无法正常显示这些历史记录。这种情况在Windows系统...
1. **SQL监视**:SQLTracker可以实时监控数据库中的SQL语句,记录每个查询的执行细节,包括执行时间、CPU使用率、I/O操作等,帮助识别慢查询和性能瓶颈。 2. **性能分析**:通过分析SQL语句的执行计划,SQLTracker...
10. **历史记录**:SQLTracker通常会保存SQL语句的执行历史,便于回顾和对比,找出性能变化的原因。 综上所述,SQLTracker是一款强大的Oracle数据库监控工具,它为数据库管理提供了宝贵的洞察力,有助于保持系统的...