用户提交commit后,数据库干的工作有:
1,oracle为用户的transaction生成一个SCN号。
2,LGWR把redo buffer中的数据写入到redo log file,同时把SCN号记录到redo log file中。这一步完成后,说明用户提 交的数据已经安全的写到磁盘
3,释放用户session占用的locks,这些locks可以在V$LOCK中查到。释放用户的lock后,那么其他在等待lock的session 就会被唤醒,继续它们的工作
4,如果在commit后,用户transaction修改的一些blocks依然在buffer cache中,这些blocks会被快速的visited,并被 cleaned out。block cleanout是指清除存储在block header中的和lock想关的信息。这一步不会产生redo信息。
从上面看,用户commit,只是把redo log buffer中的数据写入到redo log中,实际上并没有把真正的用户提交的数据(data buffer cache中的脏数据)写入到磁盘。DBWn分散的把脏数据组成“一团”,交给OS,让OS去写,而自己去收集下一个“团”。
本文详细解析了用户提交commit后,数据库(如Oracle)内部进行的一系列关键操作,包括生成SCN号、将redo buffer中的数据写入到redologfile、释放session占用的locks以及清理缓存中的blocks等。这些操作确保了用户提交的数据安全持久地存储在磁盘上。
1139

被折叠的 条评论
为什么被折叠?



