Oracle工作过程及原理.docxVIP

  1. 1、本文档共16页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
我们从一个用户请求开始讲,ORACLE的完整的工作机制是怎样 的,首先一个用户进程发出一个连接请求,如果使用的是主机命名或者 是本地服务命中的主机名使用的是机器名(非IP地址),那么这个请求 都会通过DNS服务器或HOST文件的服务名解析然后传送到 ORACLE监听进程,监听进程接收到用户请求后会采取两种方式来处 理这个用户请求,下面我们分专用服务器和共享服务器分别采用这两 种方式时的情况来讲: 专用服务器模式下:一种方式是监听进程接收到用户进程请求后, 产 生一个新的专用服务器进程,并且将对用户进程的所有控制信息传给 此服务器进程,也就是说新建的服务器进程继承了监听进程的信息, 然后服务器进程给用户进程发一个 RESEND包,通知用户进程可以 开始给它发信息了,用户进程给这个新建的服务器进程发一个 CONNECT包,服务器进程再以ACCEPT包回应用户进程,致此, 用户进程正式与服务器进程确定连接。我们把这种连接叫做 HAND-OFF连接,也叫转换连接。另一种方式是监听进程接收到用 户进程的请求后产生一个新的专用服务器进程, 这个服务器进程选用 一个TCP/IP端口来控制与用户进程的交互,然后将此信息回传给监 听进程,监听进程再将此信息传给用户进程, 用户进程使用这个端口 给服务器进程发送一个CONNECT包,服务器进程再给用户进程发 送一个ACCEPT包,致此,用户进程可以正式向服务器进程发送信 息了。这种方式我们叫做重定向连接。 HAND-OFF连接需要系统平 台具有进程继承的能力,为了使 WINDOWSNT/2000 支持 HAND-OFF必须在 HKEY_LOCAL_MACHINESOFTWAREORACLEHOMEX 中设 置 USE_SHARED_SOCKET。 共享服务器模式下:只有重定向连接的方式,工作方式是监听进程接 收到用户进程的请求后产生一个新的调度进程, 这个调度进程选用一 个TCP/IP端口来控制与用户进程的交互,然后将此信息回传给监听 进程,监听进程再将此信息传给用户进程, 用户进程使用这个端口给 调度进程发送一个CONNECT包,调度进程再给用户进程发送一个 ACCEPT包,致此,用户进程可以正式向调度进程发送信息了。 可以 通过设置MAX_DISPIATCHERS这个参数来确定调度进程的最大数 目,如果调度进程的个数已经达到了最大, 或者已有的调度进程不是 满负荷,监听进程将不再创建新的调度进程, 而是让其中一个调度进 程选用一个TCP/IP端口来与此用户进程交互。调度进程每接收一个 用户进程请求都会在监听进程处作一个登记,以便监听进程能够均衡 每个调度进程的负荷,所有的用户进程请求将分别在有限的调度进程 中排队,所有调度进程再顺序的把各自队列中的部分用户进程请求放 入同一个请求队列,等候多个 ORACLE的共享服务器进程进行处理 (可以通过SHARED_SERVERS参数设置共享服务器进程的个数), 也就是说所有的调度进程共享同一个请求队列,共享服务器模式下一 个实例只有一个请求队列,共享服务器进程处理完用户进程的请求后 将根据用户进程请求取自不同的调度进程将返回结果放入不同的响 应队列,也就是说有多少调度进程就有多少响应队列, 然后各个调度 进程从各自的响应队列中将结果取出再返回给用户进程。 以上我们讲完了用户与 ORACLE的连接方式,下面我们要讲 ORACLE服务器进程如可处理用户进程的请求,当一个用户进程发出 了一条 SQL 语名:UPDATETABBLEASETSALARY=SALARY*2 ;首 先,服务器进程把这条语句的字符转换成 ASCII等效数字码,接着这 个ASCII码被传递给一个HASH函数,并返回一个HASH值,服务 器进程将到SHAREDPOOL的共享PL/SQL区去查找是否存在同样 的HASH值,如果存在,服务器进程将使用这条语句已高速缓存在 SHAREDPOOL中的已分析过的版本来执行,如果不存在,服务器进 程将对该语句进行语法分析,首先检查该语句的语法的正确性, 接着 对语句中涉及的表、索引、视图等对象进行解析,并对照数据字典检 查这些对象的名称以及相关结构,并根据 ORACLE选用的优化模式 以及数据字典中是否存在相应对象的统计数据和是否使用了存储大 纲来生成一个执行计划或从存储大纲中选用一个执行计划,然后再用 数据字典核对此用户对相应对象的执行权限,最后生成一个编译代 码。ORACLE将这条语名的本身实际文本、HASH值、编译代码、 与此语名相关联的任何统计数据和该语句的执行计划缓存在 SHAREDPOOL的共享PL/SQL区。服务器进程通过 SHAREDPOOL 锁存器来申请可以向哪些共享 PL/SQL区中缓存这此内容,也就是说 被SHAREDPOOL锁

文档评论(0)

zsmfjh + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档