- 浏览: 1742082 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (520)
- Oracle (10)
- Oracle错误集 (8)
- Oracle安装升级 (15)
- Oracle日常管理 (51)
- Oracle字符集 (7)
- Oracle备份恢复 (24)
- Oracle优化 (4)
- Oracle编程 (52)
- Oracle导入导出 (19)
- Oracle体系结构 (15)
- Oracle网络 (2)
- Oracle安全 (2)
- Oracle权限 (3)
- Oracle数据字典和性能视图 (2)
- Oracle常用地址 (5)
- SQLPLUS专栏 (7)
- SqlServer (13)
- SqlServer2005编程 (27)
- SqlServer2005管理 (15)
- MySQL (20)
- Dorado应用 (1)
- C# (24)
- Arcgis Server开发 (20)
- ArcSDE技术 (19)
- UML学习 (2)
- 设计模式 (2)
- JAVA EE (4)
- JavaScript (3)
- OFBIZ (27)
- JAVA WEB开发 (22)
- Linux&Unix (34)
- SHELL编程 (14)
- C语言 (11)
- 网络协议 (14)
- FREEMARKER (2)
- GROOVY (2)
- JAVA语言 (3)
- 防火墙 (0)
- PHP (2)
- Apache (2)
- Loader Runner (1)
- Nginx (3)
- 数据库理论 (2)
- maven (1)
最新评论
-
怼怼怼怼:
oracle的timestamp类型使用 -
怼怼怼怼:
oracle的timestamp类型使用 -
怼怼怼怼:
oracle的timestamp类型使用 -
pg_guo:
感谢
oracle中查看用户权限 -
xu234234:
5、MapResourceManager控件中添加了两个服务, ...
北京ArcGis Server应用基础培训笔记1
一、什么是注册?
c?6zRc0注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。ITPUB个人空间*iG1Oe+x
在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)
!@)Z}6O b0相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。
%q'K(YIS3I `0二、静态注册
!o b;ei+X%aC0f0静态注册就是实例启动时读取listener.ora文件的配置,将实例和服务注册到监听程序。无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。ITPUB个人空间0_p-CC m2n|h
静态注册时,listener.ora中的GLOBAL_DBNAME向外提供服务名,listener.ora中的SID_NAME提供注册的实例名。
"H7\3[M Ndi/mF0采取静态注册方法时,listener.ora中的内容如下:
6v4~n&u)OR0SID_LIST_LISTENER =ITPUB个人空间4}*t'}3U'P$k#V
(SID_LIST =
sLGQ*S;L[0 (SID_DESC =
y s_F!O u0 (SID_NAME = PLSExtProc)
8`*u}i9cc"S4I0 (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
"I'z'qc5xe0 (PROGRAM = extproc)
(u%V;A^#E&W0 )ITPUB个人空间XR9L!a8Z~0F
(SID_DESC =
`!V,` V$?4X"XS0 (GLOBAL_DBNAME =orcl)
JR0WB {0c y&tR%CM0 (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
^@p$h~,G0 (SID_NAME =orcl)
(L-U P4o F0 )ITPUB个人空间*bg y cT8aH(Y"W
(SID_DESC =ITPUB个人空间:^L:X @o
(GLOBAL_DBNAME =orcl1)ITPUB个人空间E$b c9B*W0UP
(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)ITPUB个人空间&E8x*V;lFl `^J
(SID_NAME =orcl)ITPUB个人空间8k(O2u \.],`
)
k%E9J0r,]JY0)ITPUB个人空间3D.J,Z%~&}yY1N
该文件表明数据库是单实例的,实例名为orcl,向外提供了两个服务:orcl和orcl1ITPUB个人空间 }z+z!K\1T-f)NM`
三、动态注册
动态注册是ORACLE实例在启动时,或使用命令ALTER SYSTEM REGISTER 或每隔一分钟,实例的PMON会向监听进行注册,告知监听,实例的服务名,实例名等信息。
5H(}bUnj6B0动态注册是在instance启动的时候PMON进程根据init.ora中的instance_name,service_names两个参数将实例和服务动态注册到listener中。
C2?.w:O6[3o0首先要在init.ora中指定instance_name,service_names两个参数的值。在sqlplus下通过show parameter service_names 和show parameter instance_name可以查看这两个参数的值。ITPUB个人空间a(K/^9D$s ejQ jE z
注册到监听器中的实例值从init.ora文件中的instance_name参数取得。如果该参数没有设定值,那么它将取init.ora文件中的db_name的值。
X$C4p$DP0注册到监听器中的服务值从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被注册到监听器中:
+De}:h+be1q0db_domain=oracle.comITPUB个人空间G?1a}/dN]!R1D3\(Y
service_names=orcl ;
"S,eNt*N3c5}0采取动态注册方法时,listener.ora中的内容如下:
`;RJI9Xq/E%Z"X0SID_LIST_LISTENER =
ZFWFs0 (SID_LIST =ITPUB个人空间6YH(_Lfg9Kb4o
(SID_DESC =ITPUB个人空间I[S y,Ffpxz0] S
(SID_NAME = PLSExtProc)ITPUB个人空间'\LNwj G)G
(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
(cR y;OY+i&V/K${+z0 (PROGRAM = extproc)ITPUB个人空间0^,p9Hk]7{'Z0? J@
)ITPUB个人空间HxoReKl;s
)
w;y nQw3MRS&n$E0
cSQXxhb0可选择的是,您可以在service_names参数中指定多个服务值,值之间用逗号格开,这对于共享服务器配置是很有用的。ITPUB个人空间Hp l }4x^t
动态注册默认只注册到默认的监听器上(名称是LISTENER、端口是1521、协议是TCP),如果需要向非默认监听注册,则需要配置local_listener参数!
oF[rLj0
0S]'f4Ulk'?0如果没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行之后启动时,动态注册才会发生;在这种情况下,如果监听器后来发生了重启,动态注册信息将会丢失。显然,最好在所有的数据库启动之前先启动监听器,这样就会避免没有显式设置service_names和instance_name的值时,若重启监听器带来的动态注册信息丢失的情况。
uf,oe8e%pDA \[w0为初始化参数service_names和instance_name设置显式的值是个值得可取的方法和建议。因为如果监听器在数据库运行过程中要重新启动,仅当你在init.ora文件中显式地设置了service_names和instance_name的值时,每个数据库的PMON进程才会在很短的时间之内完成动态注册。ITPUB个人空间x;[Nd.HI
四、查询某服务是静态注册还是动态注册ITPUB个人空间2B \+f$LA^d @
可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。
.ns3~|kX0ITPUB个人空间H%VT"rX*@u4P[
实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连接请求时,它才检查该实例是否存在。ITPUB个人空间0RwH#R ^)L ^
动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管关闭何时数据库,动态注册的数据库都会动态地从监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是知道它的状态。该信息将被用于连接请求的回退(fallback)和负载平衡。
发表评论
-
Linux下开机自动启动Oracle的设置
2015-01-13 16:17 1459具体方法如下: 1. 修改oratab (root用户执 ... -
删除表空间
2014-07-14 09:19 934-删除空的表空间,但是不包含物理文件 drop table ... -
oracle删除外键约束-禁用约束-启用约束
2014-06-06 16:49 1523oracle删除外键约束-禁用约束-启用约束 执行 ... -
如何删除带有外键关系的主表,并快速重建相应的外键关系 ref_constraint
2014-06-06 16:30 10921,备份主表数据。可以用 CREATE TABLE AS S ... -
oracle中修改表字段sql语句
2014-05-15 18:09 1513oracle中修改表字段常用语句如下: 1、重命名表 AL ... -
oracle中查询所有外键引用到某张表的记录
2014-05-14 14:40 1287分为两步: 1.查询表的主键约束名 select * ... -
Oracle 创建 DBLink 的方法
2014-05-06 10:01 8441、如果需要创建全局 DBLink,则需要先确定用户有创建 ... -
CREATE TABLESPACE命令详解
2014-04-22 15:43 1403语法描述: CREATE [UNDO] TABLESPA ... -
SGA和PGA推荐配置
2014-01-23 09:07 1245查询SGA和PGA: SQL> show para ... -
oracle用户LANG和NLS_LANG环境变量设置
2014-02-14 14:14 1640export LANG=en_US.UTF-8 NLS_ ... -
几个常用的数据库操作以及视图
2014-02-19 16:48 1554一.查看表空间剩余百分比 SELECT tablespa ... -
orapwd 工具建立密码文件遵守的命名方法
2014-02-19 16:48 843orapwd 工具建立建立的密码文件一定要orapw+实例 ... -
oracle删除数据文件
2014-02-19 16:48 3640在我们详细介绍之前,我们必须说清楚一点:Oracle不提供 ... -
Oracle Undo表空间介绍
2014-02-22 08:53 1423UNDO表空间的作用和管 ... -
ALTER DATABASE 与 ALTER TABLESPACE OFFLINE的区别
2014-02-22 08:52 1008一.DataFile脱机或联机的两种方法: ① ALTE ... -
获取表空间、用户和外键的DDL语句
2013-10-24 16:22 897工作中,需要现场返回所有表空间及用户信息 get_ddl ... -
利用dbms_metadata.get_ddl查看DDL语句
2013-10-24 16:20 1225本文转载,原文地址为:http://czmmiao.itey ... -
临时表空间数据文件的迁移方法
2013-04-28 15:27 1418对于临时表空间数据文件的迁移方法如下:alter tables ... -
表空间数据文件移动或改名操作
2013-04-24 10:23 1100sqlplus /nologSQL> conn /as ... -
Duties of Oracle Database Administrators
2013-03-17 22:47 905The principal responsibility o ...
相关推荐
相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立...
Oracle listener详解 包括静态注册和动态注册 OS认证和口令文件认证方法等
TcpListener类以同步阻塞方式提供于监听和接收外来连接请求的方法。 TcpClient类实现了使用发送和接收数据的套接字。 在c# .NET中,远程连接被表示为流,所以可以用流处理方式读取和写入而进行通信。
相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立...
杂记(一):Listener、Filter和工具 杂记(一):Listener、Filter和工具
Aynchronous TCPListener 异步 server和client学习资源。可以借鉴
Servlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的...
基于Spring的listener和Task,Spring的初始化和定时任务(Task)
Filter和Listener区别
1.通过注解扫描完成Listener组件的注册 1.创建一个类实现 ServletContextListener (具体实现哪个Listener根据情况来判断) 2.在类上加入注解 @WebListener 3.重写 contextInitialized() 与 contextDestroyed...
TcpClient TcpListener Demo 案例 TcpClient TcpListener Demo 案例 TcpClient TcpListener Demo 案例 TcpClient TcpListener Demo 案例 QQ:574311505
C# 用TcpClient和TcpListener实现的功能 可以和网络通讯 此次只为了实现事件接受功能 希望能一起学习
TcpListener 监听服务端,可实现多客户端连接
Listener监听器 JavaBean Servlet Jsp XML HTML JAVA WEB开发技术 Listener监听器 事件监听器用于对程序中发生的事件进行监听,在监听的过程中会涉及几个重要组成部分: 事件(Event) 事件源 事件处理器 事件监听器...
listener监听器小例子
java jsp listener小用法,记录登录次数。
TcpListener和TcpClient模拟客户端和服务端交互,以及重连
mac_Listener
Android Listener侦听的N种写法
四、监听动态注册和静态注册 14 1、注册 14 2、动态注册 15 3、自定义端口的动态注册 16 3.1 增加tnsname.ora服务注册 16 3.2修改local_listener参数注册 17 4、静态注册 17 5、查看注册类型 18 五、监听日志基本...