说一说如何配置Oracle的MTS Part1

** 一、 ** ** 简介 **

MTS ( Multi-Threaded Server )是 ORACLE SERVER 的一个可选的配置选择,是相对 DEDICATE 方式而言,它最大的优点是在以不用增加物理资源(内存)的前提下支持更多的并发的连接。换句话说,如果你只有 2G 的物理内存,而你又想支持 2000 个连接,在获取最好性能的前提下,你就应该选择 MTS 了。

本文先说一说 MTS 的工作方式,然后与 DEDICATE 方式的做一下比较,接下来说一下 MTS 具体配置实现,最后说一些优化 MTS 配置选项的问题。

** 二、 ** ** MTS ** ** 的工作方式 **


1、 Joseph C.Johnson 以餐馆给出一个 MTS 的形象的比喻

假设 ORACLE 是一家餐馆,当你走进一家餐馆时你感觉最舒服的服务方式就是有一个专门的 waiter 来为你服务,而不管餐馆中来了多少人,她只对你请求应答,这是 DEDICTE 的处理方式,也就是说每一个 ORACLE 客户端的连接都有一个专门的服务进程来为它服务。而大部的餐馆的服方式都不是一对一的,当你走进的时侯,你就被指定了一个 waiter ,她也可能为其它桌服着务,这对于餐馆来说是最有利的,因为他们可以服务更多的客人而不需要增加他们的员工。这样对你来说也可能是不错的,如果餐馆不是太忙,她服务的客人的请求都很简短且容易完成,你的感觉也好像自己拥有一个专门的 waiter , waiter 把你的 ORDER 转给厨师,然后把做好的菜拿给你,这就是 MTS 的处理方式,这些共享的 waiters 我们叫她们为 Dispatchers ,厨师我们则叫他们为 Shared Server Processes 。

2、 以简图说一下 MTS 的工作方式 (SYBEX 书中的一幅图 )

  1. 客户端向 Dispatcher 发一个服务请求

  2. Dispatch 把这个请求放到 SGA 区的请求对队列中

  3. 由一个或几个服务进程来处理这个请求

  4. 服务进程把进行的结果放到 Dispatch 的 SGA 区的的响应队列中

  5. Dispatcher 从响应队列拾起结果

  6. 完成客户端的请求并把结果回送给客户端

** 三、 MTS 与 DEDICATE 方式方面做一下比较,为方便比较绘制如下的简表 **

** 序号 **

|

** 比较项 **

|

** MTS ** ** 方式 **

|

** DEDICATE ** ** 方式 **

---|---|---|---

1

|

服务进程

|

多个连接共享一个服务进程

|

一个连接有一个专门的服务进程

2

|

每个客户端的连接使用的内存量

|

3-4M

|

150-200K

3

|

适合的应用环境

|

适合连接数很多且请求很短少的 OLTP 环境

|

如果 Oracle 服务器的资源够用,这种方式是优选

4

|

CPU 负载

|

会造成一些 CPU 的负载,如果你的 CPU 有瓶颈,则不要用这种方式

|

Published At
Categories with 数据库类
Tagged with
comments powered by Disqus