- 浏览: 557532 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (340)
- Spring (4)
- Hibernate (2)
- Linux (34)
- Oracle (145)
- Eclipse (1)
- UML (1)
- HTML&&JAVASCRIPT (11)
- JAVA (33)
- 设计模式 (1)
- 版本控制 (1)
- wrap框架 (3)
- IBATIS (5)
- Ruby (1)
- DWR (1)
- MINA (11)
- JBPM (2)
- 缓存技术 (4)
- 网络 (3)
- 应用服务器 (1)
- GWT (5)
- 杂谈 (2)
- ICE (4)
- XML (2)
- ArcGis (2)
- Flex (8)
- junit单元测试 (1)
- SNMP (1)
- 存储 (1)
- office (1)
- MongoDB (0)
- Greenplum (3)
- 管理点滴 (1)
- C++ (6)
- 网络入门 (3)
- Tomcat (7)
- JMX (0)
- webservice (1)
- Oracle的10046事件 (1)
- Library cache内部机制详解 (1)
- expdp通过dblink来导入 (1)
最新评论
-
yuanliangding:
有没有关于mock的更多知识。
基于mock对象和JUnit框架简化Spring Web组件单元测试 -
saup007:
ssh端口不是22,怎么搞呢?
Greenplum 学习笔记 -
springmvc-freemarker:
java开源项目源码实例下载
Apache上全部JAVA开源项目简介 -
bobbell:
哇塞,你真厉害,整理的非常全面。我是一个java barcod ...
Greenplum 学习笔记 -
wsj55133245513324:
这不是bug,你将日志级别从debug提升到INFO 就好了 ...
Spring,smppapi,apache mina, ssl快速实现安全的smpp(5)
Tkprof工具可用来格式化sql trace产生的文件,让你更容易看懂trace的内容
prscpu:cpu time parsing
prsela:elapsed time parsing
prsdsk:number of disk reads during parse
prsqry:number of buffers for consistent read during parse
prscu:number of buffers for current read during parse
prsmis:number of misses in library cache during parse
execnt:number of execute was called
execpu:cpu time spent executing
exeela:elapsed time executing
exedsk:number of disk reads during execute
exeqry:number of buffers for consistent read during execute
execu:number of buffers for current read during execute
exerow:number of rows processed during execute
exemis:number of library cache misses during execute
fchcnt:number of times fetch was called
fchcpu:cpu time spent fetching
fchela:elapsed time fetching
fchdsk:number of disk reads during fetch
fchqry:number of buffers for consistent read during fetch
fchcu:number of buffers for current read during fetch
fchrow:number of rows fetched
userid:userid of user that parsed the cursor
REM statement as your needs dictate.
CREATE TABLE tkprof_table
(
date_of_insert DATE
,cursor_num NUMBER
,depth NUMBER
,user_id NUMBER
,parse_cnt NUMBER
,parse_cpu NUMBER
,parse_elap NUMBER
,parse_disk NUMBER
,parse_query NUMBER
,parse_current NUMBER
,parse_miss NUMBER
,exe_count NUMBER
,exe_cpu NUMBER
,exe_elap NUMBER
,exe_disk NUMBER
,exe_query NUMBER
,exe_current NUMBER
,exe_miss NUMBER
,exe_rows NUMBER
,fetch_count NUMBER
,fetch_cpu NUMBER
,fetch_elap NUMBER
,fetch_disk NUMBER
,fetch_query NUMBER
,fetch_current NUMBER
,fetch_rows NUMBER
,ticks NUMBER
,sql_statement LONG
);
INSERT INTO tkprof_table VALUES
(
SYSDATE, 1, 0, 61, 1, 0, 418, 0, 0, 0, 1
, 1, 15625, 1435, 0, 0, 0, 0, 0
, 4, 0, 4417, 0, 24, 0, 36, 13450151
, ’select * from tblinventoryhistory
‘);
alter session set events '10046 trace name context forever,level 12';
select * from tblinventoryhistory ;
select * from tblorder ;
select * from tblproduct ;
select * from tbluser ;
select * from tblroute ;
——- —————————————————
0 SELECT STATEMENT GOAL: CHOOSE
0 TABLE ACCESS (FULL) OF 'TBLROUTE'
2 p.spid || '.trc' trace_file_name
3 from (select p.spid
4 from sys.v$mystat m, sys.v$session s, sys.v$process p
5 where m.statistic# = 1
6 and s.sid = m.sid
7 and p.addr = s.paddr) p,
8 (select t.instance
9 from sys.v$thread t, sys.v$parameter v
10 where v.name = 'thread'
11 and (v.value = 0 or t.thread# = to_number(v.value))) i,
12 (select value from sys.v$parameter where name = 'user_dump_dest') d;
——————————————————————————–
/opt/oracle/admin/hsjf/udump/hsjf_ora_1026.trc
注意:最后排序是按照各个选项的数字之和进行排序,类似于order by (sort1+sort2+sort3),而不是order by sort1,sort2,sort3
oracle性能优化:如何讀懂tkprof
CALL :每次SQL语句的处理都分成以下三个部分
Parse:这步将SQL语句转换成执行计划,包括检查是否有正确的授权和所需要用到的表、列以及其他引用到的对象是否存在。
Execute:这步是真正的由Oracle来执行语句。对于insert、update、delete操作,这步会修改数据,对于select操作,这步就只是确定选择的记录。
Fetch:返回查询语句中所获得的记录,这步只有select语句会被执行。
COUNT:这个语句被parse、execute、fetch的次数。
CPU:这个语句对于所有的parse、execute、fetch所消耗的cpu的时间,以秒为单位。
ELAPSED:这个语句所有消耗在parse、execute、fetch的总的时间。
DISK:从磁盘上的数据文件中物理读取的块的数量。一般来说更想知道的是正在从缓存中读取的数据而不是从磁盘上读取的数据。
QUERY:在一致性读模式下,所有parse、execute、fetch所获得的buffer的数量。一致性模式的buffer是用于给一个长时间运行的事务提供一个一致性读的快照,缓存实际上在头部存储了状态。
CURRENT:在current模式下所获得的buffer的数量。一般在current模式下执行insert、update、delete操作都会获取buffer。在current模式下如果在高速缓存区发现有新的缓存足够给当前的事务使用,则这些buffer都会被读入了缓存区中。
ROWS: 所有SQL语句返回的记录数目,但是不包括子查询中返回的记录数目。对于select语句,返回记录是在fetch这步,对于insert、update、delete操作,返回记录则是在execute这步。
B、Parse count/Execute count parse count应尽量接近1,如果太高的话,SQL会进行不必要的reparse
C、rows Fetch/Fetch Fetch Array的大小,太小的话就没有充分利用批量Fetch的功能,增加了数据在客户端和服务器之间的往返次数。
D、disk/query+current 磁盘IO所占逻辑IO的比例,太大的话有可能是db_buffer_size过小(也跟SQL的具体特性有关)
E、elapsed/cpu 太大表示执行过程中花费了大量的时间等待某种资源
F、cpu Or elapsed 太大表示执行时间过长,或消耗了了大量的CPU时间,应该考虑优化
G、执行计划中的Rows 表示在该处理阶段所访问的行数,要尽量减少
alter session set timed_statistics=true;
alter session set events '10046 trace name context forever, level 12';
select 'Hello, world; today is '||sysdate from dual; exit;
发表评论
-
expdp通过dblink来导入
2011-12-14 15:01 1789create.sql: spo create.log rem ... -
Library cache内部机制详解
2011-12-14 14:55 891Library cache内部机制详解 http://www ... -
Oracle的10046事件
2011-12-14 14:53 2098Oracle的10046事件,可以跟踪应用程序所执行的SQL语 ... -
REDO LOG MEMBER STATUS 和 REDO LOG GROUP STATUS
2011-12-14 14:51 928V$LOG 中列出的是REDO LOG GROUP STA ... -
oracle的exp/imp使用方法学习(转)
2011-08-30 08:54 964exp/imp两个命令可以说是oracle中最常用的命令了 ... -
oracle几个awr报告
2011-08-09 14:25 900工作中,碰到的数据库慢的几个awr报告 -
Oracle Profile 使用详解
2011-06-21 14:41 972一、目的: Oracle系统中的profile可以用来对 ... -
ORA-27013
2011-04-13 14:25 1515很新的一个bug,看下你的 memory_target是不是& ... -
ACLE表连接方式分析及常见用法
2011-03-23 09:14 1114摘要: 针对在数据仓库 ... -
ORACLE 外部表应用
2011-03-09 14:58 1068SQL> create or replace direc ... -
How to convert a 32-bit database to 64-bit database on Linux
2011-02-18 14:09 1215How to convert a 32-bit databas ... -
expdp impdp 数据库导入导出命令详解
2011-02-16 09:10 1956一、创建逻辑目录,该命令不会在操作系统创建真正的目录,最 ... -
Oracle手工解/锁表
2011-01-25 14:15 2506手工锁表:lock table tbl_t1 in row ... -
oracle动态性能视图
2011-01-22 10:47 862Oracle动态性能视图个人整理 -
RBO规则介绍
2011-01-17 16:45 1078•无条件使用索引•使用内置的优先级别决定访问路径•比较难以 ... -
关于排序、sort_area_size、临时表空间
2011-01-13 15:30 1120简单陈述一下:针对每 ... -
创建索引ORACLE 需要做的工作
2011-01-13 14:53 1324一. 先来看一下创建索引要做哪些操作:1. 把inde ... -
表之间的连接
2011-01-13 10:42 798Join是一种试图将两个表结合在一起的谓词,一次只能连接2 ... -
重建索引的条件
2011-01-12 16:43 955如果索引存在碎片,那每个索引数据块上的索引数据就更少,会导致我 ... -
利用USE_INDIRECT_DATA_BUFFERS突破32位的2G内存限制
2011-01-09 09:35 1612对于绝大部分32位系统上的32位数据库,内存最大的设置都不能超 ...
相关推荐
实验目的明确指出,学习此工具的使用是为了让学员能够熟练地对Oracle跟踪文件进行分析。实验环境是基于VmWare Server 1.0.4运行的Red Hat Enterprise Linux as 4,以及安装的Oracle 10g数据库版本**.*.*.*.0。这种...
5. 性能监控与调优:使用Oracle的性能分析工具(如SQL*Plus、 tkprof 和AWR报告)进行性能监控,并学习如何通过调整SQL语句、索引或系统参数来优化性能。 6. 集群与高可用性:理解Oracle Real Application Clusters...
使用工具如SQL*Plus、Explain Plan、TKPROF等进行分析。 5. **数据库安全**:学习如何设置用户权限、角色、审计、加密,以及如何通过网络配置保护数据库不受攻击。 6. **备份与恢复**:理解RMAN(恢复管理器)和...
这可能涵盖使用Oracle的性能监控工具,如V$视图、SQL Trace和TKPROF,以及通过EXPLAIN PLAN理解查询执行计划。此外,优化索引策略、调整表分区、使用绑定变量、预编译SQL和内存管理也是关键的优化手段。 在压缩包中...
你可能学习了SELECT语句的使用,包括如何选择、聚合和排序数据,以及如何使用子查询和联接操作。此外,也可能涉及到了索引的概念和作用,以及如何创建和管理索引以提高查询性能。 第九天的笔记可能涵盖了备份与恢复...
这涉及到SQL调优、数据库参数调整、物理结构优化等多个层面,需要通过工具如SQL*Plus、SQL Developer、 tkprof 和 explain plan 来进行分析和改进。 总的来说,"Oracle学习资料.zip"可能包含了从基础到高级的各种...
Oracle数据库是全球广泛使用的大型关系型数据库管理系统,尤其在企业级应用中占据重要地位。...通过系统地学习和实践,新手可以快速掌握Oracle数据库的基础知识,为进一步深入学习和使用Oracle打下坚实基础。
- 查询优化:学习如何编写高效的SQL查询,理解索引的作用和使用,以及如何避免全表扫描。 - 分析工具:了解 tkprof 和 explain plan 等工具,用于分析和优化查询执行计划。 5. **备份与恢复**: - 数据库备份:...
6. **数据库性能监控与调优**:了解性能分析工具如SQL Trace、TKPROF,学习AWR(Automatic Workload Repository)和ASH(Active Session History)报告的解读,以及如何通过PGA和SGA调整内存结构。 7. **数据库备份...
14. **数据库故障诊断**:学习使用Oracle的诊断工具,如trace文件、alert log和 tkprof,进行问题排查。 15. **集群与RAC**:Oracle 10g支持Real Application Clusters (RAC),这是一种高可用性解决方案,允许多台...
7. **性能优化**:学习使用Explain Plan分析SQL执行计划,理解如何使用SQL Trace和 TKPROF进行性能调优。掌握AWR(Automatic Workload Repository)和ASH(Active Session History)报告的解读。 8. **数据仓库和...
7. 性能优化:Oracle提供了一系列工具和方法来监控和优化数据库性能,如SQL Trace和 tkprof 可用于分析查询性能,Explain Plan可以帮助理解查询执行计划,而索引策略和分区策略是常见的性能提升手段。 8. 数据备份...
6. **故障诊断与问题解决**:学习使用告警日志、跟踪文件、 tkprof 和expdp/impdp 等工具进行问题排查,以及如何使用AWR(Automatic Workload Repository)和ASH(Active Session History)进行性能监控。...
理解PL/SQL的语法、异常处理、游标、变量声明及使用是进阶Oracle学习的重要部分。 4. **数据库设计**:良好的数据库设计能确保数据的一致性和完整性。学习ER图(实体关系模型)、范式理论(1NF, 2NF, 3NF, BCNF)...
了解如何分析SQL执行计划,使用 Explain Plan 和 tkprof 工具,以及调整初始化参数都是性能优化的必备技能。 7. **PL/SQL**:Oracle的扩展SQL,它允许编写存储过程、函数、触发器等程序逻辑。掌握PL/SQL编程可以...
学习如何创建和使用视图,以及视图在数据安全和简化查询中的作用。 七、存储过程和函数 存储过程和函数是预编译的SQL语句集合,可封装复杂的业务逻辑。学习如何定义、调用和管理这些对象,以及参数传递、返回值等...
8. **性能调优**:学习如何使用SQL*Plus、 tkprof 和 Explain Plan进行SQL查询优化。理解Oracle的性能监控工具,如V$视图和AWR(Automatic Workload Repository)报告。 9. **数据库设计**:学习如何根据业务需求...
最后,了解Oracle的性能优化工具和方法,如SQL Trace、TKPROF、AWR(Automatic Workload Repository)和ASH(Active Session History),以及SQL优化顾问,可以帮助找出性能瓶颈,提升数据库运行效率。 总的来说,...
12. **数据库连接工具**:Oracle提供SQL*Plus命令行工具,还有如Toad、SQL Developer等图形界面工具,学习使用这些工具可以更便捷地管理和操作数据库。 以上是Oracle学习的一些主要知识点,这份"Oracle学习ppt"将...
7. **性能优化**:通过学习SQL优化器、索引策略、数据库调优工具(如 tkprof 和 awr 报告),可以提高数据库的运行效率,减少等待事件,提升系统性能。 8. **故障诊断与问题排查**:Oracle的日志系统(如Alert Log...