Oracle软件结构
Oracle内存结构 1、SGA(System Global Area)系统全局区1.1 数据高速缓存
数据高速缓存保存的是最近从数据文件中读取的数据块,其中的数据可以被所有用户共享。当被访问的数据只在数据文件中的时候,Oracle将读取磁盘上的数据文件,然后将其放入数据高速缓存中,再对数据进行处理;如果被访问的数据已经存在于数据高速缓存中,Oracle将直接使用数据高速缓存中的数据,而不必再从磁盘上读取数据文件了。
数据高速缓存是由许多大小相等的缓存快组成的:
A.脏缓存块。脏缓存块中保存的是已经修改过的缓存块。当一条SQL语句对某个缓存块中的数据修改后,这个缓存块就被标记为脏缓存块。它们是迟早要通过DBWR进程写入到数据文件中的。
B.空闲缓存块。空闲缓存块中没有数据,它等待被写入数据。
C.命中缓存块。命中缓存块保存的是最近正在被访问的缓存块,命中缓存块将始终保留在数据高速缓存中,不会被写入数据文件。
Oracle通过两个列表来管理上述缓存块
A.DIRTY列表保存已经被修改但还未写入数据文件的脏缓存块
B.LRU(Least Recently Used)列表保存所有空闲缓存块、命中缓存块、以及还没有被移入DIRTY列表的脏缓存块。Oracle在将数据文件中的数据块复制到高速缓存中之前,必须现在数据高速缓存中找到空闲的缓存块以便容纳该数据块。所以Oracle将从LRU列表的尾部开始搜索,直到找到所需要的空闲块为止。在搜索LRU列表的时候,如果先找到的是脏缓存块,就将其移到DIRTY列表中,然后继续搜索。如果搜索到的是空闲缓存块,就将数据写入其中,然后将该缓存块移入到LRU列表头部。如果没有搜索到足够的空闲缓存块,即不能将所有数据块都写入到对应的空闲缓存块中,则Oracle先停止对LRU的搜索,激活DBWR进程,开始将DIRTY列表选中的脏缓存块写入到数据文件中。已经被写入到数据文件的脏缓存块将变成空闲缓存块,并被放入LRU列表中。
页:
[1]