oracle静态注册,动态注册,共享服务器配置

来源:互联网 发布:js 相对路径 绝对路径 编辑:程序博客网 时间:2024/06/18 18:18

1,静态注册默认端口多个服务名配置,listener.ora

LISTENER =  (DESCRIPTION_LIST =    (DESCRIPTION =      (ADDRESS = (PROTOCOL = TCP)(HOST = centos7)(PORT = 1521))      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))    )  )# a,上边是构建数据库自动创建监听时候的一些配置,如果采用默认,全部为动态注册,以下是追加,后边不在显示# b,修改完listener之后使用lsnrctl reload重新加载# c,如果监听比数据库启动的晚,默认一分钟之后数据库PMON进程会注册,否则可以使用alter system register手动注册SID_LIST_LISTENER=  (SID_LIST =    (SID_DESC =      (GLOBAL_DBNAME = cdb10)      (ORACLE_HOME =/u01/app/oracle/product/12.2.0.1/db_1)      (SID_NAME = cdb1)    )    (SID_DESC =      (GLOBAL_DBNAME = cdb20)      (ORACLE_HOME = /u01/app/oracle/product/12.2.0.1/db_1)      (SID_NAME = cdb1)    )  )
重新加载监听文件即可,lsnrct reload,可以看到提供了两个服务名cdb10,cdb20

Listening Endpoints Summary...  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=centos7)(PORT=1521)))  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521)))Services Summary...Service "cdb10" has 1 instance(s).  Instance "cdb1", status UNKNOWN, has 1 handler(s) for this service...Service "cdb20" has 1 instance(s).  Instance "cdb1", status UNKNOWN, has 1 handler(s) for this service...The command completed successfully

2,非默认端口多个监听配置

配置监听lsnr2,追加listener.ora,当然也可以配置多个非默认端口的服务

LSNR2 =  (DESCRIPTION_LIST =    (DESCRIPTION =      (ADDRESS = (PROTOCOL = TCP)(HOST = centos7)(PORT = 1523))      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1523))    )  )
由于非默认端口必须满足两个条件,一个是修改初始化参数LOCAL_LISTENER,另一个是监听会读取TNSNAME.ora文件
所以这里需要alter system set local_listener='LSNR2';
然后再tnsname.ora文件添加LSNR2 =
  (ADDRESS = (PROTOCOL = TCP)(HOST = centos7)(PORT = 1523))
说明:这里可以注册多个端口,写多行即可,注意和上面的监听里的端口匹配
以上配置完之后可以使用客户端的1523端口进行连接

3,共享服务器配置

注意processes和session区别,这里500个session,300分给了共享服务,调度程序3个最大10个,共享服务进程10个最大30

SQL> show parameter processesNAME                                 TYPE        VALUE------------------------------------ ----------- ------------------------------aq_tm_processes                      integer     1asm_io_processes                     integer     20db_writer_processes                  integer     1gcs_server_processes                 integer     0global_txn_processes                 integer     1job_queue_processes                  integer     4000log_archive_max_processes            integer     4processes                            integer     300SQL> alter system set sessions=500 scope=spfile;System altered.SQL> alter system set shared_server_sessions=300 scope=spfile;System altered.SQL> alter system set dispatchers='(protocol=tcp)(dispatchers=3)' scope=spfile;System altered.SQL> alter system set max_dispatchers=10;System altered.SQL> alter system set shared_server=10 scope=spfile;alter system set shared_server=10 scope=spfile                 *ERROR at line 1:ORA-02065: illegal option for ALTER SYSTEMSQL> alter system set shared_servers=10 scope=spfile;System altered.SQL> alter system set max_shared_servers=30 scope=spfile;System altered.
重启服务器,以便生效配置
如果想关闭共享模式:alter systemset shared_servers = 0 ;即可
查看此时服务状态:
[oracle@centos7 admin]$ lsnrctl services lsnr2LSNRCTL for Linux: Version 12.2.0.1.0 - Production on 24-NOV-2017 16:10:41Copyright (c) 1991, 2016, Oracle.  All rights reserved....Service "cdb1" has 1 instance(s).  Instance "cdb1", 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:1022 state:ready         DISPATCHER <machine: centos7, pid: 2572>         (ADDRESS=(PROTOCOL=tcp)(HOST=centos7)(PORT=61964))      "D001" established:1 refused:0 current:1 max:1022 state:ready         DISPATCHER <machine: centos7, pid: 2570>         (ADDRESS=(PROTOCOL=tcp)(HOST=centos7)(PORT=62794))      "D000" established:1 refused:0 current:0 max:1022 state:ready         DISPATCHER <machine: centos7, pid: 2568>         (ADDRESS=(PROTOCOL=tcp)(HOST=centos7)(PORT=39753))...Service "cdb40" has 1 instance(s).  Instance "cdb1", status UNKNOWN, has 1 handler(s) for this service...    Handler(s):      "DEDICATED" established:0 refused:0         LOCAL SERVERService "pdb2" has 1 instance(s).  Instance "cdb1", 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:1022 state:ready         DISPATCHER <machine: centos7, pid: 2572>         (ADDRESS=(PROTOCOL=tcp)(HOST=centos7)(PORT=61964))      "D001" established:1 refused:0 current:1 max:1022 state:ready         DISPATCHER <machine: centos7, pid: 2570>         (ADDRESS=(PROTOCOL=tcp)(HOST=centos7)(PORT=62794))      "D000" established:1 refused:0 current:0 max:1022 state:ready         DISPATCHER <machine: centos7, pid: 2568>         (ADDRESS=(PROTOCOL=tcp)(HOST=centos7)(PORT=39753))The command completed successfully
可以看到cdb1有三个调度器,D001,D002,D003

4,客户端配置

# 专用服务器连接CDB_D =  (DESCRIPTION =    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.97.189)(PORT = 1523))    (CONNECT_DATA =      (SERVER = DEDICATED)      (SERVICE_NAME = cdb1)    )  )# 共享服务器连接CDB_S =  (DESCRIPTION =    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.97.189)(PORT = 1523))    (CONNECT_DATA =      (SERVER = SHARED)      (SERVICE_NAME = cdb1)    )  )
据此可以使用客户端连接查看

如果想查看效果,连接属于共享还是专有,SELECT SID,USERNAME,STATUS,SERVER,PROCESS FROM V$SESSION
如果是专有服务器连接,每个连接的服务器会分配一个进程,

[oracle@centos7 admin]$ ps -aef | grep oracle$ORACLE_SIDoracle    2602  1688  0 15:04 ?        00:00:04 oraclecdb1 (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))oracle    4196  1413  0 16:16 pts/0    00:00:00 grep --color=auto oraclecdb1[oracle@centos7 admin]$ ps -aef | grep oracle$ORACLE_SIDoracle    2602  1688  0 15:04 ?        00:00:04 oraclecdb1 (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))oracle    4207  4206  4 16:16 ?        00:00:00 oraclecdb1 (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))

5,共享服务模式,专有服务模式官网图解释

专有模式,参考官网:

共享模式:

名词解释:
 一、什么是注册?
  注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名
就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。
  在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册
到监听器中:数据库服务器对应的实例和服务。)
  相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一
个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。
  二、静态注册
  静态注册就是实例启动时读取listener.ora文件的配置,将实例和服务注册到监听程序。无论何时启动一个数据库,默认地都有
两条信息注册到监听器中:数据库服务器对应的实例和服务。
  静态注册时,listener.ora中的GLOBAL_DBNAME向外提供服务名,listener.ora中的SID_NAME提供注册的实例名。
  采取静态注册方法时,listener.ora中的内容如下:
  SID_LIST_LISTENER=
    (SID_LIST =
    (SID_DESC =
      (GLOBAL_DBNAME = cdb10)
      (ORACLE_HOME =/u01/app/oracle/product/12.2.0.1/db_1)
      (SID_NAME = cdb1)
    )
    (SID_DESC =
      (GLOBAL_DBNAME = cdb20)
      (ORACLE_HOME = /u01/app/oracle/product/12.2.0.1/db_1)
      (SID_NAME = cdb1)
    )
    )
  该文件表明数据库是单实例的,实例名为orcl,向外提供了两个服务:cdb10和cdb20
三、动态注册
  动态注册是在instance启动的时候PMON进程根据init.ora中的instance_name,service_names两个参数将实例和服务动态注册到
listener中。
  首先要在init.ora中指定instance_name,service_names两个参数的值。在sqlplus下通过show parameter service_names 和show
parameter instance_name可以查看这两个参数的值。
  注册到监听器中的实例值从init.ora文件中的instance_name参数取得。如果该参数没有设定值,那么它将取init.ora文件中的
db_name的值。
  注册到监听器中的服务值从init.ora文件中的参数service_names取得。如果该参数没有设定值,数据库将拼接init.ora文件中的
db_name和db_domain的值来注册自己。如果选择提供service_names值,您可以使用完全限定的名称(比如 orcl.oracle.com)或缩写
的名称(比如orcl)。如果选择缩写的名称并设置了db_domain参数,注册到监听器中的服务将是 service_name值和db_domain值的拼
接。例如下面的设置将导致服务orcl.oracle.com被注册到监听器中:
  db_domain=oracle.com
  service_names=orcl ;
    这样需要配置
    alter system set db_domain='oracle.com' scope=spfile;
    alter database rename global_name to orcl.oracle.com;
    另外监听中global_name也需要响应调整(GLOBAL_DBNAME=orcl.us.oracle.com)

  采取动态注册方法时,listener.ora中的内容可以为空
  可选择的是,您可以在service_names参数中指定多个服务值,值之间用逗号格开,这对于共享服务器配置是很有用的。
  动态注册默认只注册到默认的监听器上(名称是LISTENER、端口是1521、协议是TCP),如果需要向非默认监听注册,则需要配置
local_listener参数!
  如果没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行之后启动时,动态注册才会发生;在这种
情况 下,如果监听器后来发生了重启,动态注册信息将会丢失。显然,最好在所有的数据库启动之前先启动监听器,这样就会避免没
有显式设置 service_names和instance_name的值时,若重启监听器带来的动态注册信息丢失的情况。
  为初始化参数service_names和instance_name设置显式的值是个值得可取的方法和建议。因为如果监听器在数据库运行过程中要
重新启 动,仅当你在init.ora文件中显式地设置了service_names和instance_name的值时,每个数据库的PMON进程才会在很短的 时
间之内完成动态注册。
  四、查询某服务是静态注册还是动态注册
  可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。
  实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连
接请求时,它才检查该实例是否存在。
  动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管关闭何时数据库,动态注册
的数据库都会动态地从 监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是
知道它的状态。该信息将被用于连接请求的回退 (fallback)和负载平衡

参考相关文档:
https://docs.oracle.com/cd/B28359_01/server.111/b28310/manproc001.htm#ADMIN11168
http://blog.itpub.net/29371470/viewspace-1081314/

原创粉丝点击