用户连接Oracle数据库服务器主要有两种方式:专有服务器连接和共享服务器连接,在专有服务器模式中,当客户端发出连接数据库的请

用户连接Oracle数据库服务器主要有两种方式:专有服务器连接和共享服务器连接

在专有服务器模式中,当客户端发出连接数据库的请求时,监听器负责把客户端连接到专有服务器进程,该专有服务器进程只为该会话的用户进程服务,即使处于空闲状态。专有服务器进程与用户进程之间是一一对应的,每个服务器进程都会使用系统资源,包括CPU周期和内存。

在负荷很高的系统中,由于专有服务器进程占用了内存和CPU资源,因而会对系统的可伸缩性产生负面影响,所以一般客户端要通过中间件的连接池连接到数据库的专有服务器,或者连接到数据库的共享服务器。

相关阅读:

Oracle 共享服务器(Shared Server/MTS)的配置简析

Oracle共享服务器的监听注册机制研究

在共享服务器模式中,客户端用户进程的连接请求将被监听器传送至负载最小的调度进程(dispatcher)中,调度进程负责将用户请求传递到SGA中一个公共的请求队列。空闲的共享服务器进程将完成请求队列中的用户请求,并将结果放到响应队列中,最后调度进程将取出响应队列中的结果返回给用户进程。

会话与调度进程的连接在会话期间持久存在,而与监听器的连接是短暂的。且所有的调度进程共享一个公共的请求队列,但是每个调度进程都具有独立的响应队列。

配置共享服务器

在服务器端,,共享服务器与数据库无关,而只与实例有关。通过实例动态注册,会为共享服务器自动配置监听器。

共享服务器需要配置两个必需的参数:dispatchers和shared_servers

dispatchers参数控制在实例中启动的调度进程数以及这些进程的行为(协议类型等),max_dispatchers参数指定了能够启动的调度进程数的上限。

shared_servers参数控制在实例中启动的共享服务器进程的数量。max_shared_servers参数指定了能够启动共享服务器进程数的上限,默认为processers参数值的1/8。

$grep -A 5 APPLE $TNS_ADMIN/tnsnames.ora

APPLE =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.90)(PORT = 1522))

)

SQL> !ps aux | grep ora_s0.._orcl | grep -v grep

oracle 5223 0.0 1.0 666136 15028 ? Ss 10:21 0:00 ora_s000_orcl

SQL> show parameter dispatchers

NAME TYPE VALUE

------------------------------------ ----------- ----------------------------------

dispatchers string (PROTOCOL=TCP) (SERVICE=orclXDB)

max_dispatchers integer

SQL> alter system set dispatchers='(PROTOCOL=TCP) (dispatchers=3)'; //创建3个调度进程D000、D001、D002

SQL> select name,network,paddr,status from v$dispatcher;

NAME NETWORK PADDR STATUS

----- ----------------------------------------------------------------- -------------------- ----------------

D000 (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=62238)) 000000007AC8AFF0 WAIT

D001 (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=54626)) 000000007AC8C030 WAIT

D002 (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=16374)) 000000007AC8D070 WAIT

SQL> !ps aux | grep ora_d0.._orcl | grep -v grep

oracle 9303 0.0 1.0 666976 15992 ? Ss 15:35 0:00 ora_d000_orcl

oracle 9392 0.0 1.0 666976 15976 ? Ss 15:38 0:00 ora_d001_orcl

oracle 9396 0.0 1.0 666976 16004 ? Ss 15:38 0:00 ora_d002_orcl

SQL> alter system set shared_servers=6; //创建6个响应队列S000~S005(一般为dispatchers的倍数)

SQL> select name,paddr,status,circuit from v$shared_server;

NAME PADDR STATUS CIRCUIT

---- ---------------- ---------------- ----------------

S000 000000007AC8E0B0 WAIT(COMMON) 00

S001 000000007AC8F0F0 WAIT(COMMON) 00

S002 000000007AC90130 WAIT(COMMON) 00

S003 000000007AC91170 WAIT(COMMON) 00

S004 000000007AC921B0 WAIT(COMMON) 00

S005 000000007AC94230 WAIT(COMMON) 00

SQL> !ps aux | grep ora_s0.._orcl | grep -v grep

oracle 5223 0.0 1.0 666136 15028 ? Ss 10:21 0:00 ora_s000_orcl

oracle 6692 0.1 1.0 666136 15028 ? Ss 11:13 0:00 ora_s001_orcl

oracle 6696 0.1 1.0 666136 15028 ? Ss 11:13 0:00 ora_s002_orcl

oracle 6700 0.0 1.0 666136 15032 ? Ss 11:13 0:00 ora_s003_orcl

oracle 6704 0.1 1.0 666136 15044 ? Ss 11:13 0:00 ora_s004_orcl

oracle 6708 0.1 1.0 666136 15032 ? Ss 11:13 0:00 ora_s005_orcl

SQL> alter system set dispatchers='(PROTOCOL=TCP) (dispatchers=3) (listener=apple)'; //单独将dispathers注册到LISTENER1的监听器上

SQL> !lsnrctl service listener1

---------------省略输出---------------

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.0.90)(PORT=1522)))

Services Summary...

Service "orcl.example.com" has 1 instance(s). Instance "orcl", status READY, has 4 handler(s) for this service...

Handler(s):

"DEDICATED" established:0 refused:0 state:ready

LOCAL SERVER

"D002" established:0 refused:0 current:0 max:972 state:ready

DISPATCHER (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=16374))

"D001" established:0 refused:0 current:0 max:972 state:ready

DISPATCHER (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=54626))

"D000" established:0 refused:0 current:1 max:972 state:ready

DISPATCHER (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=62238))

The command completed successfully

更多详情见请继续阅读下一页的精彩内容:

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网

oracle972,配置Oracle共享服务器相关推荐

  1. 六、配置Oracle数据库的网络环境

    1. 连接建立的过程 场景:oracle默认监听器1521,把数据库服务注册到监听器中,客户端才能通过监听器登录到数据库上操作, 数据库的名称是orcl,注册后,叫服务命名 [oracle@oracl ...

  2. OCM_第二天课程:Section1 —》配置 Oracle 网络环境

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  3. 系统dsn oracle,linux平台配置oracle odbc dsn的方法.docx

    linux平台配置oracle odbc dsn的方法.docx LINUX平台配置ORACLEODBCDSN的方法1DSN配置方法ORACLE11编辑配置文件一.OSRHEL5X86(ORACLED ...

  4. linux下配置oracle 10G EM Database Console

    1.启动dbconsole [oracle@devrfel501 ~]$ emctl start dbconsole 如果提示:OC4J Configuration issue. /opt/oracl ...

  5. centos oracle 服务自动启动,CentOS下配置Oracle 11gR2为系统服务自动启动

    CentOS下配置Oracle 11gR2为系统服务自动启动 CentOS下配置Oracle 11gR2为系统服务自动启动 为什么80%的码农都做不了架构师?>>> PS:在Wind ...

  6. Cognos配置oracle类型内容库时报错

    Cognos配置oracle类型内容库时报错 Cognos初次安装,创建内容库为Oracle数据库类型的时候,报下面的错误 [Content Manager database connection] ...

  7. Win7环境配置Oracle 11g安装与配置过程

    这篇随笔作为新人的我的开场,主要用来帮助我自己以后在Win7环境配置oracle 11g时能有个提醒.当然不同Windows版本安装大同小异,所以也可以给需要的人一些借鉴. 一:下载安装包 直接从官网 ...

  8. 配置ORACLE 客户端连接到数据库

    --================================= -- 配置ORACLE 客户端连接到数据库 --================================= Oracle ...

  9. win7配置远程连接oracle数据库吗,win7环境下配置oracle数据库的方法有哪些?

    1win7数据库. 在服务中停止所有的oracle相关服务: 2win7数据库. 删除注册表中以下三个位置的oracle相关文件夹: 3win7数据库. 在环境变量中path中win7数据库,删除or ...

最新文章

  1. 如何取小数点前两位并四舍五入?
  2. 用js获取当前地理位置的经纬度
  3. 负载均衡设备oracle,Oracle RAC 服务器端联接负载均衡(Load Balance)
  4. django 按钮的样式_【实战演练】Python+Django网站开发系列11-成绩查询与成绩录入...
  5. QML-关于Qt.rgba()颜色无法正常显示问题
  6. Configure VNC in RHEL 7
  7. 面向单片机编程(一)- 单片机该怎么学
  8. Spring动态代理中有什么方法不会被代理探究
  9. 阿里云-对象存储OSS
  10. 一种兼顾速度和效果的对比度增强算法——CONTRAST ENHANCEMENT BASED ON LAYERED DIFFERENCE REPRESENTATION
  11. 【Typora启动报错】This beta version of Typora is expired, please download and install a newer version.
  12. Spark 连接kafka报错: Error while fetching metadata with correlation id xx [topicName=INVALID_REPLICATIO]
  13. 10亿数据导入oracle方案
  14. windbg挂代理下载pdb
  15. Pymoo:优化算法的性能指标(Performance Indicators)
  16. 无人机技术将从硬件创新转向自动化智能飞行
  17. フェルミナ / 风拳
  18. 完全模拟FIFA2014世界杯 原创求顶!
  19. Vue详解+实战分析
  20. C# 校验类(邮箱、手机号、身份证号等)

热门文章

  1. 基因表达数据批次效应去除方法的研究进展
  2. java web编程 servlet3
  3. mysql增删改查笔记
  4. 不败精灵游戏攻略分析
  5. CF707C Pythagorean Triples 题解
  6. kotlin sealed 中_Kotlin 数据类与密封类
  7. java打开网页空白_网页打开后是空白 怎么回事
  8. 抖音如何定位?抖音技巧必知的13种玩法
  9. 基于AT89S51的单片机无线双显示抢答器简要说明
  10. 一、Linux的简要介绍