微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Oracle的专用数据库和共享数据库区别

专用服务器进程(Dedicated server)


对于专用服务器配置,在登录时,Oracle总会创建一个新的进程,这个服务器进程会在会话生存期中专门这个连接服务。对于每个会话,都会出现一个新的专用服务器,会话与专用服务器之间存在一对一的映射。按照定义,这个专用服务器不是实例的一部分用户进程和服务器进程是分开的。每个用户进程都有自己的服务器进程。
用户进程和服务器进程可在不同的机器上运行,以利用分布式处理的优势。
用户进程和服务器进程的比率是1 比1。
即使用户进程不发出数据库请求,专用服务器也存在,只是保持空闲状态。
何时使用专用服务器
提交批作业(预计很少有或没有空闲时间)
以sysdba 身份连接以启动、关闭或执行恢复
要请求使用专用服务器,必须在tnsnames.ora 文件内的Oracle Net TNS 连接字符串中
包含SERVER=DEDICATED 子句。
注:对于大多数平台来说,如果您的机器有足够的内存支持专用服务器,则应使用专用服
务器。这样性能可能更好些。
但也有例外,例如Windows NT,在该系统中,由于共享服务器体系结构的异步特性,使
用Oracle Shared Server 配置性能可能会有所提高。
如何连接专用服务器
在客户端服务器中的tnsnames.ora文件里进行设置:
dedicated =(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST =192.168.1.52)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = itpux)
(server = dedicated)
)





共享服务器(shared server),正式的说法是多线程服务器(Multi-Threaded Server)或MTS。如果采用这种方式,就不会对每条用户连接创建另外的线程或新的UNIX 进程
Oracle Shared Server 的优点
减少针对某一例程的进程数目
增加可服务的用户
实现负载平衡
减少空闲服务器进程的数目
减少内存占用和系统开销
如何连接共享服务器
不能使用共享服务器执行某些类型的数据库工作:
数据库管理
备份和恢复操作
批处理和批量加载操作
数据仓库操作
共享服务器具有以下一些缺点
一般我们以oracle认的专用服务器方式就行了,没必要使用共享服务器模式。一个是我们是使用中间件(如:weblogic)去连oracle的,中间件本身有连接池机制,另外就是oracle的这个共享服务器方式也做的不够好了,有诸多缺点。
1)共享服务器的代码路径比专用服务器长,所以它天生就比专用服务器慢。
2)存在人为死锁的可能,因为它是串行的,只要一个连接阻塞,则该服务器进程上的所有用户都被阻塞,并且极可能死锁。 ITPUX 技术网(http://www.itpux.com),中国最专业最全面的 IT 行业技术网站。
3)存在独占事务的可能,因为如果一个会话的事务运行时间过长,它独占共享资源,其它用户只能等待,而专用服务器,每个客户端是一个会话。
4)共享服务器模式限制了某些数据库特性,例如:不能单独启动和关闭实例,不能进行介质恢复,不能使用Log miner,并且sql_TRACE没有意义(因为是共享而不是当前会话的)。


怎么知道oracle当前是 DEDICATED SERVER 还是 SHARED SERVER?
最简单的一个方法是查看监听: lsnrctl service

[grid@udevasm:/home/grid]$lsnrctlservice
LSNRCTLforLinux:Version11.2.0.4.0-Productionon15-JUL-201713:07:31
copyright(c)1991,2013,Oracle.Allrightsreserved.
Connectingto(DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1521)))
ServicesSummary...
Service"+ASM"has1instance(s).
Instance"+ASM",statusREADY,has1handler(s)forthisservice...
Handler(s):
"DEDICATED"established:0refused:0state:ready
LOCALSERVER
Service"db01"has1instance(s).
Instance"udevasm",has1handler(s)forthisservice...
Handler(s):
"DEDICATED"established:8refused:0state:ready
LOCALSERVER
Service"udevasm"has1instance(s).
Instance"udevasm",has1handler(s)forthisservice...
Handler(s):
"DEDICATED"established:8refused:0state:ready
LOCALSERVER
Service"udevasmXDB"has1instance(s).
Instance"udevasm",has1handler(s)forthisservice...
Handler(s):
"D000"established:0refused:0current:0max:1022state:ready
disPATCHER<machine:udevasm,pid:2469>
(ADDRESS=(PROTOCOL=tcp)(HOST=udevasm)(PORT=10275))
Thecommandcompletedsuccessfully

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Java Oracle 结果集是Java语言中处理数据库查询结果的一种方式。通常情况下,Java程序会通过JDBC连接Oracle数据库并执行一条查询语句,返回一个ResultSet结果集。ResultSet是一个行集,包含了查询语句的返回结果。在
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密。在计算机通信领域,AES加密算法是一种十分重要的保密技术,被广泛应用于银行、保险、互联网电子支付等重要场合。
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台性等优势,被广泛应用于企业级应用开发。而Oracle11g是一个强大的关系型数据库,由于其优秀的可靠性、安全性和扩展性,已经被广泛应用于企业级应用中。Jav
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的组成部分。为了满足移动端用户的需求,我们可以使用jQuery开发移动端大转盘抽奖活动。
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常被用来搭建高效的软件系统。Java是一种面向对象的编程语言,而Oracle是一种关系型数据库管理系统。Java 和Oracle在应用中的联系非常紧密,它们能够通过相互
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上,而 Oracle 是一个广泛使用的数据库软件。在 Java 对 Oracle 进行操作时,需要使用 Oracle 参数来确保程序正确工作。本文将从 Oracle 参数的定义、分类
随着电子竞技的兴起,越来越多的人开始慕名玩起了王者荣耀。而对于Python爱好者来说,这款游戏也有着很大的吸引力。因为Python可以帮助我们获取并处理游戏数据,从而获得更好的游戏体验。
Java与Oracle在数据处理方面都有着非常重要的地位,而在Java和Oracle的结合中,Integer类型则起到了不可替代的作用。Integer类型是Java中一个非常常用的数据类型,它可以表示范围在-2147483648到2147483647之间的整数
如今,JavaScript已经成为了web开发的必备技能之一,而IE浏览器也是众多开发者最常用的浏览器,那么,如何启用IE浏览器的JavaScript呢?
Java与Oracle是当今软件行业中广泛使用的两个技术。而SP(Stored Procedure)是Oracle数据库中存储过程的组件,可以在Java中调用Oracle数据库中的SP。在开发过程中,Java和Oracle的组合可以方便处理大规模的数据和建