Re: How to size UNDO for a database?
Date: Mon, 25 Mar 2013 13:47:45 -0700 (PDT)
Message-ID: <1364244465.17671.YahooMailNeo_at_web121602.mail.ne1.yahoo.com>
You can't create a tablespace with autoextend maxsize 32768M (I already have a good UNDO tablespace so I created another, for illustrative purposes):
SQL> create tablespace wamboonie datafile 'C:\ORADB\ORADATA\SMEDLEY\WAMBOONIE.DBF' size 128m autoextend on next 2 128m maxsize 32768m;
create tablespace wamboonie datafile 'C:\ORADB\ORADATA\SMEDLEY\WAMBOONIE.DBF' size 128m autoextend on next *
ERROR at line 1:
ORA-03206: maximum file size of (4194304) blocks in AUTOEXTEND clause is out of range
SQL>
You can do this:
SQL> create tablespace wamboonie datafile 'C:\ORADB\ORADATA\SMEDLEY\WAMBOONIE.DBF' size 128m autoextend on next
2 128m maxsize 32767m 3 /
Tablespace created.
SQL>
The largest you can go is 32767M; 32G won't work, either, for the same reason.
Other than that small niggle Tim's advice is excellent; I do the same thing for databases I manage and I get a clear picture of the UNDO usage at a glance.
David Fitzjarrell
From: Tim Gorman <tim_at_evdbt.com>
To: oracle-l_at_freelists.org
Sent: Monday, March 25, 2013 2:34 PM
Subject: Re: How to size UNDO for a database?
Ann,
Make the UNDO tablespace autoextensible, starting with a relatively 
small size, incrementing in relatively small "chunks", with a maximum 
file size that is standard for your environment.
For example, assuming that I'm running in an environment where the largest datafile I wish to backup (and restore) is 32 Gb, and I've decided to allocate Oracle-managed datafiles on ASM or file-system space in 128 Mb chunks, I'll use something like...
create undo tablespace undo01 datafile size 128m autoextend on next 128m maxsize 32768m;
This allows you to start with something small, then over time to let it size itself, so that after a few days, weeks, or months of normal operation, you'll be able to look at V$UNDOSTAT and have an excellent idea of what normal undo usage is for the workload hitting your database.
Nothing is better than actual usage information for your environment.
If you fear running out of space even so, set the parameter RESUMABLE_TIMEOUT to a non-negative value, then monitor error messages to your "alert.log" file. If a resumable error is output to your alert.log, then a resumable_timeout setting of 1800 will give you 1,800 seconds (i.e. 30 minutes) to either increase AUTOEXTEND MAXSIZE or add another datafile or otherwise deal with the issue. Again, notice that the idea is to use these mechanisms to find the proper setting for your specific workload, which nobody else on this list can begin to guess at.
Hope this helps!
Thanks!
Tim Gorman
consultant -> Evergreen Database Technologies, Inc.
postal    => PO Box 352151, Westminster CO 80035-2151 USA
web/blog  => http://www.EvDBT.com/
email      => Tim_at_EvDBT.com
mobile    => +1 (303) 885-4526
twitter    => timothyjgorman
president -> Rocky Mtn Oracle Users Group (http://www.rmoug.org/) board -> Oracle Developers Tools Users Group (http://www.odtug.com/) advisor -> Northern California Oracle Users Group (http://www.nocoug.org/) secretary -> Project SafeGuard (http://www.psghelps.org/)member -> OakTable Network (http://www.oaktable.net/)
Oracle ACE Director (www.oracle.com/technetwork/community/oracle-ace)
Lost Data? => www.ora600.be/ for info about DUDE...
On 3/25/2013 1:02 PM, Apps DBA wrote:
> Hi Gurus,
> I would like to know how to analyze and size undo for a busy database or
> while design itself. As the transactions increasing for a busy DB like
> reporting or DW DB we usually face lot of jobs failing with snapshot too
> old error. Please share your knowledge.
>
> Thanks,
> Ann
>
>
> --
> http://www.freelists.org/webpage/oracle-l
>
>
>
>
-- http://www.freelists.org/webpage/oracle-l -- http://www.freelists.org/webpage/oracle-lReceived on Mon Mar 25 2013 - 21:47:45 CET
