Warning: You should NOT implement the following tips on production databases at any cost, as this will stop the database recoverability features which may lead to data loss in case of system crash or will disable logging mechanisms which can undermine problems troubleshooting!
Disable Flashback: [Flashback log generation is accounted for 2% to 10% of the overhead on the DB]
SQL> ALTER DATABASE FLASHBACK OFF;
Disable Archivelog mode: [Disabling archivelog mode can boost the overall DB performance significantly]
SQL> shutdown immediate
SQL> startup mount
SQL> alter database noarchivelog;
SQL> alter database open;
Disable Force Logging:[Force logging can put a huge load on Redo Log files even if the database in NOARCHIVELOG mode:
SQL> ALTER DATABASE no force logging;
Disable auditing:
SQL> ALTER SYSTEM SET audit_trail='NONE' scope=spfile;
Disable Recycle bin:[Objects will be permanently dropped even when you don't specify PURGE keyword]
SQL> ALTER SYSTEM SET recyclebin=off deferred;
Disable block corruption checking mechanism:
Block checking for detecting block corruption can add extra I/O to each write activity on DB blocks.
SQL> ALTER SYSTEM SET DB_BLOCK_CHECKING=FALSE;
SQL> ALTER SYSTEM SET db_block_checksum=OFF;
SQL> ALTER SYSTEM SET "_dlm_stats_collect"=0 SCOPE=SPFILE;
Disable Automatic Shared Memory Management (ASMM): [Applicable to production as well 👍]
If you know the optimal size for each memory component, then it's better to set them manually rather than having ASMM to do it for you, trust me; even if don't figure out the optimal size for memory pools you still can adjust them better than ASMM.
Set the following parameter to the optimal size (as possible):
SQL> ALTER SYSTEM SET shared_pool_size=nnnn scope=both;
SQL> ALTER SYSTEM SET "_shared_pool_reserved_pct"=10 scope=spfile;
SQL> ALTER SYSTEM SET large_pool_size=nnnn scope=both;
SQL> ALTER SYSTEM SET java_pool_size=nnnn scope=both;
SQL> ALTER SYSTEM SET db_cache_size=nnnn scope=both;
SQL> ALTER SYSTEM SET streams_pool_size=nnnn scope=both;
Then disable ASMM:
SQL> ALTER SYSTEM SET sga_target=0 scope=both;
Disable STATISTICS LEVEL:
SQL> ALTER SYSTEM SET STATISTICS_LEVEL=BASIC;
Disabling statistics level is very powerful as it will disable the following feature as well:
Automatic Workload Repository (AWR) Snapshots
Automatic Database Diagnostic Monitor (ADDM)
All server-generated alerts
Automatic SGA Memory Management
Automatic optimizer statistics collection
Object level statistics
End to End Application Tracing (V$CLIENT_STATS)
Database time distribution statistics (V$SESS_TIME_MODEL and V$SYS_TIME_MODEL)
Service level statistics
Buffer cache advisory
MTTR advisory
Shared pool sizing advisory
Segment level statistics
PGA Target advisory
Timed statistics
Monitoring of statistics
Disable DLM Statistics Collection: [Applicable to production as well 👍]
It's known to cause ora_scm* process to consume high CPU & Memory: [Doc ID 2373451.1]
SQL> ALTER SYSTEM SET "_dlm_stats_collect"=0 SCOPE=SPFILE;
Maintain only 1 big Redo Log member in each Redo Log group:
Having only one member inside each group reduces the I/Os on the disk, in addition, increasing the size of the REDO LOG file will reduce the frequent Redo Log switches.
Example:
SQL> ALTER DATABASE add logfile group 4 '/oradata/ORCL/redo4.log' size 10g;
SQL> ALTER DATABASE add logfile group 5 '/oradata/ORCL/redo5.log' size 10g;
SQL> ALTER DATABASE add logfile group 6 '/oradata/ORCL/redo6.log' size 10g;
SQL> ALTER DATABASE drop logfile group 1;
SQL> ALTER DATABASE drop logfile group 2;
SQL> ALTER DATABASE drop logfile group 3;
Increase log_buffer parameter: [Applicable to production as well 👍]
SQL> ALTER SYSTEM SET log_buffer=52428800 scope=spfile;
Increase fast_start_mttr_target:
Although increasing fast_start_mttr_target will increase the crash recovery time when the instance crash, but it can boost the database write activities as it doesn't need to be flushed from Redo Logs to the datafiles immediately.
Example: setting fast_start_mttr_target to 5 minutes:
SQL> ALTER SYSTEM SET FAST_START_MTTR_TARGET=300;
Use BIGFILE tablespace instead of default small file:
The performance advantage of Bigfile tablespace over the default small file tablespace is that it decrease the reserved memory inside SGA for managing the datafiles, along with decreasing the I/Os and space inside the controfile, if the machine that hosts your test database has humble resources this can help.
SQL > CREATE BIGFILE TABLESPACE bigtbs DATAFILE '/oradata/ORCL/App_data.dbf' SIZE 500g;
Set datafiles to AUTOEXTEND OFF: [Applicable to production as well 👍]
Make sure that datafiles have sufficient free space to accommodate new data before setting them to AUTOEXTEND OFF.
Example:
SQL>ALTER DATABASE datafile '/oradata/ORCL/users01.dbf' autoextend off ;
Use only one controlfile:
Avoid multiplexing the controlfile as this will add more I/O overhead to the hosting disk.
Example:
SQL> ALTER SYSTEM SET control_files='/oradata/ORCL/control1.ctl' scope=spfile;
Reduce the UNDO RETENTION to the minimum required to support DML operations:
SQL> ALTER SYSTEM SET undo_retention=nnn scope=both;
Disable trace_enabled parameter:
This will stop tracing system problems which is required by Oracle support for debugging.
SQL> ALTER SYSTEM SET trace_enabled=FALSE SCOPE=BOTH;
Turn OFF Listener's logging:
This supposes to stop writing log entries to the listener's logfile to reduce the I/O overhead on the underlying filesystem:
Immediate stop of listener log: [doesn't require to restart the listener but will not be considered if the
listener restart]
# lsnrctl set log_status off
Turn OFF Listener's logging: [permanent, requires a listener restart]
# vi listener.ora
logging_listener = off
# lsnrctl listener stop
# lsnrctl listener start
Turn OFF SQLNET logging:
This supposes to stop writing log entries to the sqlnet's logfile to reduce the I/O overhead on the underlying filesystem:
# vi sqlnet.ora
LOG_DIRECTORY_CLIENT = /dev/null
LOG_FILE_CLIENT = /dev/null
Stop TFA:
TFA logs all Oracle RAC and OS activities and performance data, it's mainly getting used by Oracle support to help them understand the status of the RAC node at a specific period of time.
You can stop TFA by executing this command as root user:
# /etc/init.d/init.tfa stop
Finally, If you think that I missed something "and of course there are still tons of tips that can boost the performance" please write it in the comment section. Remember to use above mentioned tips wisely and do NOT implement them on production databases to avoid getting bad Emails from HR 😁
References:
https://docs.oracle.com/cd/B28359_01/server.111/b28320/initparams246.htm#REFRN10219
https://docs.oracle.com/cd/E18283_01/server.112/e17110/initparams129.htm