Top Ten Performance Mistakes Found in Oracle Systems. (文件 ID 858539.1)
In this Document
Purpose
Troubleshooting Steps
References
--------------------------------------------------------------------------------
Applies to:
Oracle Database - Enterprise Edition - Version 9.2.0.1 to 11.1.0.7 [Release 9.2 to 11.1]
Information in this document applies to any platform.
RDBMS
Purpose
The purpose of this note is to inform reader about Top ten Performance mistakes commonly found in Oracle Systems. This list is not in any particular order or priority.
Troubleshooting Steps
Bad Connection Management
The application connects and disconnects for each database interaction. This problem is common with stateless middleware in application servers. It has over two orders of magnitude impact on performance, and is totally unscalable.
Bad Use of Cursors and the Shared Pool
Not using cursors results in repeated parses. If bind variables are not used, then there is hard parsing of all SQL statements. This has an order of magnitude impact in performance, and it is totally unscalable. Use cursors with bind variables that open the cursor and execute it many times. Be suspicious of applications generating dynamic SQL.
Bad SQL
Bad SQL is SQL that uses more resources than appropriate for the application requirement. SQL that consumes significant system resources should be investigated for potential improvement.
Use of Nonstandard Initialization Parameters
These might have been implemented based on poor advice or incorrect assumptions. Most systems will give acceptable performance using only the set of basic parameters. In particular, parameters associated with _SPIN_COUNT on latches and undocumented optimizer features can cause a great deal of problems that can require considerable investigation.
Likewise, optimizer parameters set in the initialization parameter file can override proven optimal execution plans. For these reasons, schemas, schema statistics, and optimizer settings should be managed together as a group to ensure consistency of performance.
Getting Database I/O Wrong
Many sites lay out their databases poorly over the available disks. Other sites specify the number of disks incorrectly, because they configure disks by disk space and not I/O bandwidth.
Redo Log Setup Problems
Many sites run with too few redo logs that are too small. Small redo logs cause system checkpoints to continuously put a high load on the buffer cache and I/O system. If there are too few redo logs, then the archive cannot keep up, and the database will wait for the archive process to catch up.
Serialization of data blocks
Serialization of data blocks in the buffer cache due to lack of free lists, free list groups, transaction slots (INITRANS), or shortage of rollback segments.
This is particularly common on INSERT-heavy applications, in applications that have raised the block size above 8K, or in applications with large numbers of active users and few rollback segments. Use automatic segment-space management (ASSM) to and automatic undo management solve this problem.
Long Full Table Scans
Long full table scans for high-volume or interactive online operations could indicate poor transaction design, missing indexes, or poor SQL optimization. Long table scans, by nature, are I/O intensive and unscalable.
High Amounts of Recursive (SYS) SQL
Large amounts of recursive SQL executed by SYS could indicate space management activities, such as extent allocations, taking place. This is unscalable and impacts user response time. Use locally managed tablespaces to reduce recursive SQL due to extent allocation. Recursive SQL executed under another user Id is probably SQL and PL/SQL, and this is not a problem.
Deployment and Migration Errors
In many cases, an application uses too many resources because the schema owning the tables has not been successfully migrated from the development environment or from an older implementation. Examples of this are missing indexes or incorrect statistics. These errors can lead to sub-optimal execution plans and poor interactive user performance. When migrating applications of known performance, export the schema statistics to maintain plan stability using the DBMS_STATS package.
This note is from Oracle documentation:
Oracle? Database Performance Tuning Guide
10g Release 2 (10.2)
B14211-03
References
NOTE:466181.1 - Oracle 10g Upgrade Companion
NOTE:601807.1 - Oracle 11gR1 Upgrade Companion
NOTE:215187.1 - SQLT Diagnostic Tool
NOTE:223117.1 - Troubleshooting I/O Related Waits
NOTE:228913.1 - Systemwide Tuning using STATSPACK Reports
NOTE:402983.1 - * Master Note: Database Performance Overview
NOTE:94036.1 - Init.ora Parameter "CURSOR_SHARING" Reference Note
NOTE:396940.1 - Troubleshooting and Diagnosing ORA-4031 Error [Video]
本文是否有所幫助?
是
否
文件詳細資訊
透過電子郵件傳送此文件的連結在新視窗中開啟文件可列印頁
型別:
狀態:
上次主更新:
上次更新:
TROUBLESHOOTING
PUBLISHED
2014-10-2
2014-10-2
相關產品
Oracle Database - Enterprise Edition
資訊中心
載入資訊中心
Index of Oracle Database Information Centers [1568043.2]
Information Center: Overview of Database Security Products [1548952.2]
Information Center: Overview Database Server/Client Installation and Upgrade/Migration [1351022.2]
文件引用
載入資訊中心
Oracle 10g Upgrade Companion [466181.1]
Oracle 11gR1 Upgrade Companion [601807.1]
SQLT Diagnostic Tool [215187.1]
Troubleshooting I/O Related Waits [223117.1]
Systemwide Tuning using STATSPACK Reports [228913.1]
顯示更多
最近檢視
Top Ten Tips for Performance Management on Linux on IBM System Z [1578595.1]
Top 5 Database and/or Instance Performance Issues in RAC Environment [1373500.1]
Using DBMS_UTILITY.COMPILE_SCHEMA For SYS Objects Fails With ORA-20001 ORA-06512 [225942.1]
SMON: Following Errors Trapped And Ignored ORA-21779 [988663.1]
Before DDL Trigger, Unable To Process Transactions [1399633.1]
顯示更多
未找到您要查詢的產品?在社群中提問...
相關內容
產品
?Oracle Database Products > Oracle Database Suite > Oracle Database > Oracle Database - Enterprise Edition > RDBMS > Database Level Performance Issues (not SQL Tuning)
關鍵字
ASSM;AWR;DBMS_STATS;FULL TABLE SCAN;PERFORMANCE;REDO LOG;SHARED POOL;STATSPACK;TROUBLESHOOT
返回頁首返回頁首
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/500314/viewspace-1608610/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【MOS】Top Ten Performance Mistakes Found in Oracle Systems. (文件 ID 858539.1)ORMOracle
- Oracle Performance Top Issue listOracleORM
- Find Out Top Ten Largest Files in LinuxLinux
- 【《TOP》讀書筆記】<3> Identifying Performance Problems筆記IDEORM
- 【MOS】Top 5 Grid Infrastructure Startup Issues (文件 ID 1368382.1)ASTStruct
- 【MOS】 EXPDP - ORA-39166 (Object Was Not Found) (文件 ID 1640392.1)Object
- BO performance mangement模組安裝文件.ORM
- Oracle Performance ChecklistOracleORM
- 【《TOP》讀書筆記】<1> Performance Problems筆記ORM
- go mistakesGo
- Top 5 Database and/or Instance Performance Issues in RAC EnvironmentDatabaseORM
- Ten Reasons Why Android Should Support OpenCLAndroid
- oracle performance tunningOracleORM
- Oracle Performance Tune PlanOracleORM
- Top Ten Traps in C# for C++ Programmers中文版(下篇) (轉)C#C++
- 【MOS】EXPDP Fails ORA-39165: Schema SYS Was Not Found (文件 ID 553402.1)AI
- oracle performance Features and VersionsOracleORM
- Oracle Performance Testing PrincipleOracleORM
- oracle performance tunning(1)OracleORM
- oracle performance tunning(2)OracleORM
- oracle performance tunning(3)OracleORM
- oracle performance tunning(4)OracleORM
- oracle performance tunning(5)OracleORM
- oracle performance tunning(6)OracleORM
- oracle performance tunning(7)OracleORM
- oracle performance tunning(8)OracleORM
- oracle performance tunning(9)OracleORM
- oracle performance tunning(10)OracleORM
- [Oracle Script] ASM Disks Performance metricOracleASMORM
- Oracle Performance Storyteller MERGEOracleORM
- How to use hints in Oracle sql for performanceOracleSQLORM
- webpack Performance: The Comprehensive GuideWebORMGUIIDE
- Performance Tools Quick Reference GuideORMGUIIDE
- Performance and Storage Considerations (217)ORMIDE
- 【SQL Performance Analyzer】Oracle 11g SQL Performance Analyzer feature使用SQLORMOracle
- Oracle GoldenGate Best Practice - Testing Maximum Performance of Disks in UNIX [ID 1356855.1]OracleGoORM
- Ten examples of git-archiveGitHive
- oracle.Performance.Tuning筆記OracleORM筆記