关于Oracle专用模式与共享模式的请教


今天无意之中翻到一个Word文档,打开一看居然是我在2010年1月14日,也就是一年多以前和一阵风大哥的聊天记录,是关于向他请教Oracle专用模式与共享模式的区别的,当时正好在做项目的过程中遇到了这个问题,虽然也查找过一些资料,但心里其实还是没底,而经过一阵风大哥的经验分享之后,就放心的把Oracle设置为了专用模式。
在这里,我把当时的聊天记录帖给大家,以供大家参考。

Rainbow  15:03:58
一阵风大哥。
请教你个问题。

一阵风  15:05:08
呵呵 什么问题 彩虹男

Rainbow  15:05:35
一般你Oracle用dbca建库时,是指定的共享模式还是专用模式呢?

一阵风  15:05:51
一般都是专用模式的
也是默认模式

Rainbow  15:06:07
但公司里有个前辈,他说共享模式好。
让我以后都建成共享模式。

一阵风  15:06:25
那看多少并发  还有业务方面了

Rainbow  15:06:30
我不知道它们到底有什么区别。
一般怎么来判断它们哪一种更适合业务?

一阵风  15:07:22
专用模式会为每个连接创建专有的服务进程,会分配专有的PGA 
如果你的pga比较大  专用模式比较有优的
如果并发比较大 短连接的话 共享模式好一点

Rainbow  15:09:15
好一点的话,主要是好在哪里?
速度,还是主机的资源耗用?

一阵风  15:12:21
比如 并发比较高  用专用模式比较耗资源  你可以g一下 网上有这方面说明
在dedicated server里,当你有大量的用户连接(比如,同一时间超过5000个用户连上来),你的系统负担就会相当大。而这种情况shared servers就可以处理的相对好一些,因为加入同时有5000个用户连上来而且我们知道一般只有1%的连接是active,那我们只需要设置50个 shared servers就可以把所有的用户请求处理得很好,并节省了系统资源。

Rainbow  15:16:11
知道啦,谢谢咯

一阵风  15:16:11
共享连接只是把连接SESSION信息放在LARGE POOL,所以LARGE POOL要大一些。而专用连接的SESION信息放在PGA。
不客气

Rainbow  15:16:52
那我用的10g,参数那里还用默认的百分比行不行啊?

一阵风  15:17:41
默认就行 你把SGA设置系统自动分配就行

Rainbow  15:18:02
还有就是我们有一些中间件软件,比如用Tomcat,weblogic这些之后。

一阵风  15:18:07
只设置一个sga最大值就行

Rainbow  15:18:16
是不是用共享模式就不如专用模式?

一阵风  15:18:52
我这边全是专用模式  也是tomcat  目前主要并发不是很大

Rainbow  15:19:34
按你那边的经验,如果并发达到300左右。8G内存的Server性能上如何?

一阵风  15:20:54
就用专用模式  然后把PGA设置大一点比如:5G

Rainbow  15:21:35
太感谢啦。

一阵风  15:21:43
不客气  多多交流

下面是一些总结性的言论:
---------------------------------------------------------------
共享模式适用了一种类似连接池的概念,但实际应用中效果不是很好,不知道在10g中有没有改善。
---------------------------------------------------------------
专用模式和共享模式的本质区别就是: 用户进程对ORACLE内存区里"服务器进程"的专用还是共享。
具体表现在:
1、在共享模式下,多个用户进程共享一个服务器进程,在专用模式下,ORACLE为每一个用户进程准备一个服务器进程。
2、在实际情况中,应用系统与数据库的连接请求总是很多,导致用户进程也很多,如果你的内存和CPU是有限的,同时,用户进程对数据库的操作占用空间不多,那你就把数据库连接模式设置为共享模式,这样,ORACLE内存区的服务器进程只是有限的几个,这几个服务器进程会通过一个调度程序来应付若干用户进程的请求。
3、如果你的硬件资源比较好,就设置成专用模式,每一个用户进程都有一个服务器进程对应,这样,你的用户进程对数据的处理会非常快!
---------------------------------------------------------------
简单的说,连接数少,需要长时间占用数据库的,建议用专有模式,如果连接数众多而系统资源有限,使用共享模式。
---------------------------------------------------------------

  1. No comments yet.
(will not be published)
*