当前位置:  数据库>oracle

Oracle客户端Dedicated和Shared连接模式

    来源: 互联网  发布时间:2017-06-18

    本文导语: Dedicated(专用模式)用户进程和服务器进程是分开的。每个用户进程都有自己的服务器进程。用户进程和服务器进程可在不同的机器上运行,以利用分布式处理的优势。用户进程和服务器进程的比率是1 比1。即使用户进程不发出...

Dedicated(专用模式)
用户进程和服务器进程是分开的。
每个用户进程都有自己的服务器进程。
用户进程和服务器进程可在不同的机器上运行,以利用分布式处理的优势。
用户进程和服务器进程的比率是1 比1。
即使用户进程不发出数据库请求,专用服务器也存在,只是保持空闲状态。
此处所用的程序接口取决于用户进程和专用服务器进程是否在同一台机器上。如果在同一
机器上,进程间的程序接口将使用主机操作系统的交互进程通信(IPC) 机制。
下图展示了Oracle专用服务模式下的客户进程连接状态:

Oracle客户端Dedicated和Shared连接模式[图片]Oracle客户端Dedicated和Shared连接模式[图片]
 
Shared(共享模式)
减少针对某一例程的进程数目
增加可服务的用户数
实现负载平衡
减少空闲服务器进程的数目
减少内存占用和系统开

Oracle客户端Dedicated和Shared连接模式[图片]Oracle客户端Dedicated和Shared连接模式[图片]

默认情况下数据库创建的连接模式为专享模式,但即使修改成共享连接模式以下几种情况也必定是以专享模式连接的:
当批量提交的job时(对于服务进程,一个job几乎没有空闲时间)。

使用RMAN进行备份,恢复或修复数据库时。

 
除了Dedicated和Shared,Oracle还提供了常驻连接池模式(Database Resident Connection Pooling)。这种模式主要用于web应用的请求
通过一个简单的例子来对比三种连接模式下对内存的需求:
考虑一个应用每一个会话请求的内存大小为400K,而每一个服务进程需要使用4M的内存,当pool size为100并且共享模式最大连接数为100。
 
专享模式下
Memory used = 5000 X (400 KB + 4 MB) = 22 GB
共享模式下
Memory used = 5000 X 400 KB + 100 X 4 MB = 2.5 GB
超出2.5G,2G来自于SGA区
常驻连接池
Memory used = 100 X (400 KB + 4 MB) + (5000 X 35KB)= 615 MB
这里每一个代理进程的消耗内存接近35k
 
配置共享模式
共享模式下涉及到的参数有:
SHARED_SERVERS 指定共享服务进程启动时的最小数值。
MAX_SHARED_SERVERS 指定可同时运行的共享服务进程的最大值。
SHARED_SERVERS_SESSIONS 指定可同时连接共享进程的用户会话总数。
DISPATCHERS 为共享模式配置调度进程
MAX_DISPATCHERS 指定允许同时运行的调度进程的最大数,该参数现在可能被忽略了。
CIRCUITS 指定网络会话流入流出可用的总的虚拟环路。
 
因为要开启共享模式,SHARED_SERVERS设置的值必须大于0,而其他相关配置可以不需要,当SHARED_SERVERS值大于0时,调度进程也会启动,即使没有配置dispatchers参数
 
在DBCA创建数据库的过程中,Oracle会自动创建一个用于XML DB(XDB)的调度进程。该配置仅允许会话以共享模式连接数据库,但要进行一些常规的操作(如提交SQL语句),用户必须额外的配置调度或替换XDB调度配置
 
alter system set shared_servers=5;
 
关于MAX_SHARED_SERVERS没有默认值,如果该值为空,PMON进程会根据请求开启足够多的共享服务进程。但也要受到以下参数的限制:
process 的限制

空闲process槽的最小值(至少1/8的总进程槽数,或为2当process设置的值小于24时)

系统资源

SHARED_SERVERS_SESSIONS用于限制并发共享服务的用户会话最大数,该参数是动态变化的,其中还保留了用于专享服务的数据库会话。这确保管理任务如备份,还原和恢复数据库时不会占用共享服务的会话。
 
CIRCUITS 都没有默认值,该值取决于调度参数的值和系统资源。因此尽量对其作出限制。
alter system set circuits=;
 
关于DISPATCHERS的设置:
限定地址协议和最小启用调度进程数
dispatchers='(address=(pro=tcp) (host=10.x.x.x) (dispatchers=2))'
dispatchers='(description=(address=(pro=tcp) (host=10.x.x.x) (dispatchers=2)))'
限制dispatchers的最大网络连接和会话数
dispatchers='(pro=tcp) (dispatchers=2) (conn=100) (sess=100)'
为dispatchers指定别名和服务名,用于PMON进程注册调度信息。
dispatchers='(pro=tcp) (dispatchers=2) (list=orcl) (serv=orcl)'
允许多路复用和连接池
dispatchers='(pro=tcp) (dispatchers=2) (multi=on) (poo=on)'
 
dispatchers可以多在配置文件中写多行,但是必须放在一起。或者以逗号分隔放在同一行配置中。
dispatchers='(pro=tcp) (dispatchers=2) (multi=on) (poo=on)','(pro=tcps) (dispatchers=2)'
or
dispatchers='(pro=tcp) (dispatchers=2) (multi=on) (poo=on)'
dispatchers='(pro=tcps) (dispatchers=2)'
 
如何决定调度进程的多少:
dispatchers=ceil(max_concurrent_sessions / connections for each dispatcher)
connections for each dispatcher由系统决定,一个系统允许单个进程的最大连接数即为connections for each dispatcher的取值。
 
配置TNSNAME.ORA文件,将客户端连接的SERVER方式修改成SHARED模式。
 
配置好上述参数后,就可以通过共享方式连接数据库了。连接时需要指明实例名
通过lsnrctl services命令观察实例的注册信息
sqlplus user/password@sid
 
可以通过下列视图来验证和观察性能:
select name, paddr, network, status, accept, messages, listener, conf_indx from v$dispatcher;
select maximum_connections,maximum_sessions,servers_started from v$shared_server_monitor;
select circuit,dispatcher,server,waiter,saddr,status,queue,messsages,bytes from v$circuit;
v$dispatcher_config
v$shared_server
v$queue
v$shared_pool_reserved
v$dispatcher_rate
v$sga
v$sgastat
 
修改dispatchers参数可以通过以下方式:
alter system set dispatchers=‘(index=0) (pro=tcp) (dispatchers=2) (multi=on) (poo=on)','(index=1) (pro=tcps) (dispatchers=2)';
这里的index后的值表示调度进程的序列,可以在v$dispatcher_config中获得
 
关闭特定的dispatchers进程
alter system shutdown immediate ‘name of dispatchers’
这个dispatchers的名称来自于v$dispatcher表的name字段。


    
 
 

您可能感兴趣的文章:

  • XP Oracle客户端进入Linux Oracle服务端
  • 关于JDBC连接Oracle数据库,是否必须有Oracle客户端
  • 在redhat9.0下,能安装oracle的客户端么?? 哪里下载,怎么安装?
  • Window客户端通过ADO是否能够连接和操作Unix平台下的Oracle数据库?
  • oracle的客户端要装些什么软件,才能访问到远程数据库,我急死了!!!
  • LINUX数据库oracle客户端安装问题
  • 成功实现应用程序和Oracle客户端一起打包
  • Linux 用occi 要安装 oracle客户端吗?
  • oracle数据库在客户端建立dblink语法
  • 在Linux下安装DP客户端备份Oracle
  • oracle客户端PLSQL连接失败解决方法
  • 客户端连接oracle服务器!!
  • Oracle客户端与数据库服务器连接
  • 求求各位,来看一下在RED HAT 7.1 上安装ORACLE8.1.7客户端软件时出现的问题
  • 客户端不安装Oracle也可以连接数据库
  • Linux下安装Oracle客户端
  • oracle客户端环境变量设置的问题
  • oracle查看字符集后修改oracle服务端和客户端字符集的步骤
  • Oracle客户端出现乱码的解决
  • Oracle客户端 NLS_LANG 的设置方法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 网间Oracle的连接,远程连接Oracle服务器??
  • oracle远程连接服务器出现 ORA-12170 TNS:连接超时 解决办法
  • 不想装oracle却还要在redhat8.0下用jdbc连接oracle如何实现?
  • 我用JBuilder 7连接局域网内一ORACLE 9( 在本机可以连接)的问题?
  • oracle 数据库连接分析
  • Linux系统下利用java连接Oracle 10G
  • Jbuilder 7.0 连接 Oracle 数据库
  • 怎么直接通过JDBC连接oracle?
  • 请教: Javaswing 和 Oracle JDBC thin 连接的问题
  • opendbx 为什么连接不上oracle?
  • 100分寻求最优化的连接oracle的java程序,请给我讲出理由,我是初学者,在做项目时不想让连接oracle影响我的程序性能
  • 如何在JBuilder中连接Oracle数据库?
  • 怎样调出ORACLE数据库中的数据,该如何连接?
  • 请教JSP与ORACLE连接问题。
  • jdbc连接oracle
  • 关于Jbuilder7连接oracle9??
  • 再问java 连接oracle 问题,急!
  • jsp文件连接oracle失败
  • 讨论:jdbc连接oracle数据库
  • Jsp连接Oracle的问题 ???
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3