配置Oracle共享服务器

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

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

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

相关阅读:

配置Oracle共享服务器

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

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

配置Oracle共享服务器

配置共享服务器

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

共享服务器需要配置两个必需的参数: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 <machine: ora11g.example.com, pid: 4987>
        (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=16374))
      "D001" established:0 refused:0 current:0 max:972 state:ready
        DISPATCHER <machine: ora11g.example.com, pid: 4983>
        (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=54626))
      "D000" established:0 refused:0 current:1 max:972 state:ready
        DISPATCHER <machine: ora11g.example.com, pid: 4979>
        (ADDRESS=(PROTOCOL=tcp)(HOST=ora11g.example.com)(PORT=62238))
The command completed successfully

相关推荐