对于Oracle体系结构的理解-------初步理解首先,Oracle体系架构是有一张体系图,我也是从这张图的理解。其实体系架构就是这张图,要理解体系架构就必须把这张图搞懂才行。体系图:一、oracle服务器组成rdbma是实现的一套完整的解决方案,包括instance databaseinstance :内存结构、后台进程database:物理文件、文件的逻辑结构二、内存结构1、User Process用户访问数据库建立的回话,访问数据库的方式有:1、直接在本地通过socket访问 2、通过TCP 三次握手建立连接到服务器,这种连接方式需要配置$ORACLE_HOME/NETWORK/ADMIN/TNSNAMES.ORA访问的网络地址 3、通过远程方式连接2、Seerver Process服务器进程,客户端向服务器发送一个连接就建立一个服务器进程。由于用户执行的服务要在内存中,所以要把提交的数据从进程读取到内存,即为了达到这一目的,oracle设计了PGA3、Instanceinstance即包括服务器上的各个进程,为数据库提供服务,一个instance只对应一个database,但是一个database可以有多个instance(这个在特殊情况下才有)。4、PGA (Programe Global Area)即程序全局区域,是User Process与数据库建立一个连接时,是由oracle数据库服务器本身自动分配它的内存区域,该区域是为当前用户与数据库建立回话保留的,是私有的内存区域;在创建回话时被分配,结束回话后就会释放回收。组成:它包括:UGA (User Global Area)和Stack SpaceUGA包含:User Session Date、Cursor Status、Sort Area4、SGA(System Global Area)即系统全局内存区域,在启动实例时被分配,主要用于存储数据库信息的内存区,该信息被进程共享,而从上面的图中可以看到,SGA其中又有:Shared Pool、Database Buffer Cache、Java Pool、Redo Log Buffer、Large Pool,而且共享池里面又有Library Cache、Data Dictionary Cache;共享池里面主要用于缓存被执行SQL语句和被调用的数据定义。在高速缓冲区里面存放数据库用过的数据块(即用户的高速缓冲区),而高速缓冲区又分为三个区:脏数据区(Dirty Buffers)、自由区(Free Buffers)、保留区(Pinned Buffers)5、介绍用户进程执行一个SQL查询语句时,由用户提交给服务器,再由服务器返回给用户的过程。a.用户进程先与服务器建立连接b.建立连接之后,用户把数据提交给服务器进程,服务器进程把数据信息提交给PGA中的UGA中c.信息通过UGA处理之后传递给instanced.intance中的共享池负责处理这条语句,library cache负责判断是硬分析还是软分析e.根据cdo(优化器)得到执行计划准备执行语句,过程是:先在数据字典缓存区查询语句中的对象放在哪个表空间,指定的行放在哪个块里面。f.开始执行,由于这个执行需要在内存中执行,所以在执行前还需要判断在数据缓存区data buffer cache中是否已经缓存了需要执行的块?如果是,则在内存中读取到数据得到需要的结果返回给用户;如果不是,则服务器进程把块从IO读入到data buffer cache缓存下来,然后ondo块把该块做成镜像,然后从镜像中读取数据返回给用户。更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12Oracle存储的逻辑结构和物理结构Linux系统中配置MySQL群集(MySQL Cluster)相关资讯 Oracle体系结构
- Oracle数据库体系结构详解 (今 07:38)
- Oracle体系结构总体概述 (09/18/2014 06:10:12)
- Oracle体系结构之检查点 (09/15/2013 07:14:11)
| - Oracle 数据库体系结构解析 (07/08/2015 08:32:10)
- Oracle体系结构之SQL语句的执行过 (09/15/2013 07:16:35)
- Oracle体系结构概述 (03/01/2013 08:21:58)
|
本文评论 查看全部评论 (0)