首页 > 数据库 > Oracle > 正文

说一说如何配置Oracle的MTS Part1

2020-03-09 23:58:52
字体:
来源:转载
供稿:网友


一、简介

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有瓶颈,则不要用这种方式

 

 
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表