作者:流行时尚吾诺饰品手_317 | 来源:互联网 | 2014-07-09 16:02
Oracle专用服务器和共享服务器连接Oracle服务器处理请求的两种最常用的方式,这两种方式分别是专用服务器连接和共享服务器连接。www.2cto.com专用服务器:登录时,Oracle总会为我创建一个新的线...SyntaxHighlighter.all();
Oracle专用服务器和共享服务器连接
Oracle服务器处理请求的两种最常用的方式,这两种方式分别是专用服务器连接和共享服务器连接。 www.2cto.com
专用服务器:
登录时,Oracle总会为我创建一个新的线程。这通常称为专用服务器配置,因为这个服务器进程会在我的会话生存期中专门为我服务。对于每个会话,都为出现一个新的专用服务器,会话与专用服务器之间的存在一对一的映射。按照定义,这个专用服务器不是实例的一部分。我的客户进程(也就是想要连接
数据库的程序)会通过某种网络通道(如TCP/IP套接字)与这个专用服务器直接通信,并由这个服务器进程接收和执行我的SQL。如果必要,它会读取数据文件,并在数据库的缓存中查找我要的数据。也许它会完成我的更新语句,也可能会运行我的PL/SQL代码。这个服务器进程的只要目标就是对我提交的SQL调用做出响应:
具体过程如下:
①client使用设定的协议向Listener发送一个CONNECT包,建立与Listener的连接。
②Listener检查SID是否已经被定义。如果已经被定义,Listener将fork一个新的进程来处理此连接。一个Bequeath连接就在Listener和新的服务器进程之间建立起来用于传输进程初始化信息。随后,Bequeath连接将被关闭。注意,TCP sockets是被新的服务器进程继承的。
③服务器进程会给client发送一个RESEND包。
④一个新的CONNECT包在此从client发送到fork产生的服务器进程
⑤dedicated服务器进程接到新的连接包,会返回一个ACCEPT包给client。
专用服务器请求的流程下图所示: www.2cto.com
共享服务器:
在共享服务器中,
Oracle使用一个“共享进程”池为大量用户提供服务。共享服务器实际上就是一种连接池机制。利用共享服务器,不必为每一个数据库会话都创建一个专用服务器,而只需建立很少的一部分进程/线程,这些进程/线程将有所有会话共享。这样Oracle就能让更多的用户与数据库连接,否则很难连接更多的用户。客户进程不能与共享服务器直接对话,原因在于这个服务器进程是共享的。为了共享这些进程,还需要另外一种机制,通过这种机制才能与服务器进程“对话”。
为此,Oracle使用一个或一组称为调度程序(dispatcher,也称分配程序)的进程。客户进程通过网络与一个调度程序进程通信。这个调度程序进程将客户的请求放入SGA中的请求队列(也是SGA的用途之一)。第一个空闲的共享服务器会得到这个请求,并进行处理。完成这个命令后,共享服务器会把响应放在原调度程序(即接收请求的调度程序)的响应队列中。调度程序进程一直在监听这个队列,发现有结果后,就会把结果传给客户。
具体过程如下:
①客户连接向调度器发送一个请求。调度器首先将这个请求放在SGA中的请求队列中。
②第一个可用的共享服务器从请求队列中取出这个请求并处理。
③共享服务器的处理结束后,再把响应(返回码、数据等)放到响应队列中,
④接下来调度器拿到这个响应,传回给客户。 www.2cto.com
共享服务器请求的流程下图所示:
下图展示了使用共享服务器连接的客户和使用专用服务器连接的客户之间的交互方式。由此还显示出,一个Oracle实 例可以同时使用这两类连接(实际上,即使配置为使用共享服务器连接,Oracle数据库也总是支持专用服务器连接)。