ASSM与L3、L2、L1块的意义

Oracle内核技术揭密_吕海波  学习笔记

ASSM的整体结构是3层位图块+数据块,共4层的树状结构。

第一层位图块称为L3块,一个L3块中可以存放多个L2块的地址,一个L2块可以存放多个L1块地址,一个L1块可以存放多个数据块地址。

第一个L3块一般是段头,如果段头中存放太多L2块的信息,就会空间不足,这时oracle会再分配第二个L3块。如果第二个L3块空间用完了,就会分配第三个L3块,一般2个L3块就够用了,很少用到第三个的。

oracle利用4层结构向块中插入数据的过程:

第一步:查找数据字典(dba_segments视图的基表),确定段头位置。 

第二步:在段头中找到第一个L2块位置信息。

第三步:到L2块中根据执行插入操作进程的PID号,做HASH运算,得到一个随机数N,在L2中找到第N个L1块的位置信息。

第四步:在第三步确定的L1块中,再根据PID号,做HASH运算,得到一个随机数M,在L1中找到第M号数据块。

第五步:向第M号数据块中插入数据。

L3块中虽然有多个L2块,但插入操作每次都会选择同一个L2块,直到它下面的数据块插满才会选择下一个L2块。

在L2中选择L1的时候是随机的,不同的session,只要有可能,就会被分配到不同的L1中。在L1中找数据块时也是一样的。ASSM可以支持大并发插入的原因就在这里,可以让多个session同时操作不同的数据块,假设一个L2有10个L1,每个L1有8个数据块,那么理论上ASSM可以同时支持10*8=80个session同时操作数据块。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值