您好,欢迎访问一九零五行业门户网

oracle中PCTFREE, PCTUSED, INITRANS, MAXTRANX参数

1. pctfree 要形容一个 block 的运作,我们可以把一个 block 想成一个水杯。侍者把水倒入放在我们面前的水杯,要多满呢,我们要求他倒 9 分满好了,这时候 pctfree 代表着设定为 10 ,意思就是说,当 block 使用到达 90% 的时候,就不可以在使用了,这个 blo
1. pctfree
要形容一个 block 的运作,我们可以把一个 block 想成一个水杯。侍者把水倒入放在我们面前的水杯,要多满呢,我们要求他倒 9 分满好了,这时候 pctfree 代表着设定为 10 ,意思就是说,当 block 使用到达 90% 的时候,就不可以在使用了,这个 block 应该从 freelist 列表中移除 (un-link) 。为何要保留 10% 的空间呢?这是为了提供 update 数据时所可能增加的空间使用,如果空间保留的太小,就容易发生 row chaining 。
2. pctused
pctused 代表着这杯水什么时候可以添加,假设 pctused 为 40 ,代表当我们把水杯的水喝到剩下 40% 以下时,侍者就会知道需要加水了。你想想看,如果说在餐厅里妳每喝一口水侍者就来加水,你会不会觉得很烦,对餐厅来说,也要派很多人不断帮每桌客人加水,这生意还能做吗?所以说, pctused 代表着 re-link 回 freelist 的意义,如果说 pctused 设的太大,例如 70 好了,代表这杯水你随便喝一口侍者就要来加水了,这隐含的意义是,这个杯子的利用率增加,但是侍者频繁的服务造成了负荷 (i/o overhead) 。 pctused 设小一点,例如 10 ,代表当水喝到剩下 10% 的时候 ( 如同 delete 事务操作 ) ,才须要放回 freelist ,代表可以加水了 ( 如同 insert 事务操作 ) 。
简单的说,如果希望储存空间发挥最大使用效益,可以把pctused设大一点,相反的,如果想要提高io效能,应该把pctused设定小一点。
freelist 储存着可使用的 block 信息,当 block 被 delete 数据使用量下降到 pctused 时,就会重新放置到 freelist 上,让其它交易新增数据使用。 freelist 存放在 table/index 的 segment header 中,他管理着所有可以新增数据的 block 信息。想想,如果有多人同时要新增数据而要求 freelist 提供可使用的 block 信息, freelist 不就也会成为另一个 overhead ?所以依照 table 使用的需求调整 freelist 的数量也是 io tuning 的一个重点。
这个参数在assm中已经没有用了,只剩下pctfree是生效的了。
3. initrans
initrans 指的是一个 block 上初始预分配给并行交易控制的空间 (itls)
( 当 block 上某笔 row 被交易更新锁定时,会在 block header itl allocate 一个锁,当下一个交易要更新同一笔 row 时,就会发现他已经被先前的交易持有锁了,会先去检查该交易是否 active? 如果是,后来的该笔交易就会被 blocking ,等待 ) 如果一个表格需要同时有大量交易存取,你应该设定 initrans 大一点,可以减少 itl 还要动态扩充的 overhead 。
for tables initrans defaults to 1 for indexes 2
4. maxtrans
maxtrans 指的是如果 initrans 空间不够用了,就会自动扩展 itl ,直到最大值也就是 maxtrans 值为止,预设是 255 。但是,如果 block 空间已经不足,也有可能无法持续扩充到 255 个 its 空间喔。
其它类似信息

推荐信息