本文主要是介绍db file scattered read,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
db file scattered read
一:db file scattered read说明
二:db file scattered read解决思路
三:db file scattered read重现过程
四:db file scattered read官方文档
一:db file scattered read说明
Oracle在执行全表扫描(Full Table Scan,FTS)、索引快速全扫描(Index Fast Full Scan)时,为保障性能,尽量一次性读取多个块,这称为Multi Block I/O。
每次执行Multi Block I/O,都会等待物理I/O结束,此时等待db file scattered read事件。
https://docs.oracle.com/cd/E11882_01/server.112/e41573/instance_tune.htm#PFGRF94479
This event signifies that the user process is reading buffers into the SGA buffer cache and is waiting for a physical I/O call to return. A db file scattered read issues a scattered read to read the data into multiple discontinuous memory locations. A scattered read is usually a multiblock read. It can occur for a fast full scan (of an index) in addition to a full table scan.
The db file scattered read wait event identifies that a full scan is occurring. When performing a full scan into the buffer cache, the blocks read are read into memory locations that are not physically adjacent to each other. Such reads are called scattered read calls, because the blocks are scattered throughout memory. This is why the corresponding wait event is called 'db file scattered read'. multiblock (up to DB_FILE_MULTIBLOCK_READ_COUNT blocks) reads due to full scans into the buffer cache show up as waits for 'db file scattered read'.
https://docs.oracle.com/cd/E11882_01/server.112/e40402/waitevents003.htm#BGGIBDJI
Similar to db file sequential read, except that the session is reading multiple data blocks.
二:db file scattered read解决思路
1 SQL优化
如果是某些SQL引起的,例如统计信息不准确,没有索引或使用低效的索引等,可以通过优化SQL,降低db file scattered read;
2 分区表
可以考虑将全表扫描优化成分区扫描;
3 增大BUFFER CACHE
如果db file scattered read出现特别频繁,Buffer HIT较低,可以考虑增大buffer cache;
4 使用更快的存储;
select name, parameter1, parameter2, parameter3
from v$event_name
where name = 'db file scattered read';
---查看含有db file scattered read等待事件的session;
SELECT sid, total_waits, time_waited
FROM v$session_event
WHERE event = 'db file scattered read'
and total_waits > 0
ORDER BY 2 desc;
select sid, event, p1, p2, p3, wait_class
from v$session_wait
where event = 'db file scattered read';
Check the following V$SESSION_WAIT parameter columns:
P1: The absolute file number
P2: The block being read
P3: The number of blocks (should be greater than 1)
select owner, segment_name, segment_type
from dba_extents
where file_id = 6
and 37475 between block_id and block_id + blocks - 1;
SELECT row_wait_obj# FROM V$SESSION WHERE EVENT = 'db file scattered read';
SELECT owner, object_name, subobject_name, object_type
FROM DBA_OBJECTS
WHERE data_object_id = '88605';
select v.last_call_et,
v.username,
v.sid,
sql.sql_text,
sql.sql_id,
sql.disk_reads,
v.event
from v$session v, v$sql sql
where v.sql_address = sql.address
and v.last_call_et > 0
and v.status = 'ACTIVE'
and v.username is not null;
select * from table(dbms_xplan.display_cursor('d24df9xbujb75'));
---SELECT SQL_ADDRESS, SQL_HASH_VALUE
FROM V$SESSION
WHERE EVENT LIKE 'db file%read';
三:db file scattered read重现过程
索引快速全扫描(Index Fast Full Scan)
SQL> create tablespace chenjch_tbs datafile '/u01/app/oracle/oradata/orcl/chenjch_tbs01a.dbf' size 10M autoextend on maxsize 1G;
SQL> create user chenjch identified by a default tablespace chenjch_tbs;
SQL> grant connect,resource,dba to chenjch;
SQL> create table t1 as select * from dba_objects;
SQL> insert into t1 select * from t1;
SQL> commit;
SQL> insert into t1 select * from t1;
SQL> commit;
SQL> insert into t1 select * from t1;
SQL> commit;
......
SQL> create index i_t1_001 on t1(object_id,object_name,object_type);
SQL>
begin
dbms_workload_repository.create_snapshot();
end;
SQL> alter system flush buffer_cache;
SQL> alter session set tracefile_identifier='10046';
SQL> alter session set events '10046 trace name context forever, level 12';
SQL> select /*+ index_ffs(t1 i_t1_001) */ object_id, object_name, object_type from t1 where object_id = '20';
SQL> alter session set events '10046 trace name context off';
SQL>
begin
dbms_workload_repository.create_snapshot();
end;
SQL>
select distinct (m.sid), p.pid, p.tracefile
from v$mystat m, v$session s, v$process p
where m.sid = s.sid
and s.paddr = p.addr;
---/u01/app/oracle/diag/rdbms/orcl/orcl/trace/orcl_ora_57032_10046.trc
[oracle@dip ~]$ tkprof /u01/app/oracle/diag/rdbms/orcl/orcl/trace/orcl_ora_57032_10046.trc /home/oracle/10046_3.trc
这篇关于db file scattered read的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!