undo
undo_retention:事务结束后undo信息保留时间

--设强制
alter tablespace undotbs1 retention guarantee;   
--不强制
alter tablespace undotbs1 retention noguarantee;  
undo使用:(有新事务需要undo空间)
1)如果有空闲则使用空闲
2)使用事务结束时间超过 undo_retention
3)如果undo表空间没有设置guarantee,使用事务结束
最早的,如果设置了grarantee,表空间自动扩展
4)扩展失败,报错 


看undo统计
select * from v$undostat;  //每10分钟统计一次
unxpstealcnt: 尝试使用未超过保留时间的次数
expstealcnt: 尝试使用未超过保留时间的次数
expblkreucnt: 使用未超过保留时间的次数
ssolderrcnt: “snapshot too old ”错误发生次数
nospaceerrcnt: 空间不足
maxquerylen: 最长查询时间
undoblks: 10分钟累计使用undo块

计算平均每秒产生undo块
select max(undoblks)/600 from v$undostat;


估算undo表空间大小
SQL> show parameter undo_re

NAME                                 TYPE        VALUE
------------------------------------ ----------- -----------
undo_retention                       integer     900
select (900*max(undoblks)/600 * 8 /1024)as MB from v$undostat;

设置checkpoint频率,保证数据库能在600秒内恢复,如果undo过的超过了600秒能写完的量,就会自动产生checkpoint,写一部分数据块
alter system set fast_start_mttr_target=600;


2、日志大小   还是不会算??
自数据库启动到现在累计的日志量
select value from v$sysstat where name='redo size';
7490108
产生这些日志的时间
select (sysdate-startup_time)*8 from v$instance;
1.4

800000/1.4     一个小时产生的日志量