- 浏览: 1762882 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (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 1507具体方法如下: 1. 修改oratab (root用户执 ... -
删除表空间
2014-07-14 09:19 976-删除空的表空间,但是不包含物理文件 drop table ... -
oracle删除外键约束-禁用约束-启用约束
2014-06-06 16:49 1559oracle删除外键约束-禁用约束-启用约束 执行 ... -
如何删除带有外键关系的主表,并快速重建相应的外键关系 ref_constraint
2014-06-06 16:30 11431,备份主表数据。可以用 CREATE TABLE AS S ... -
oracle中修改表字段sql语句
2014-05-15 18:09 1538oracle中修改表字段常用语句如下: 1、重命名表 AL ... -
oracle中查询所有外键引用到某张表的记录
2014-05-14 14:40 1325分为两步: 1.查询表的主键约束名 select * ... -
Oracle 创建 DBLink 的方法
2014-05-06 10:01 8941、如果需要创建全局 DBLink,则需要先确定用户有创建 ... -
CREATE TABLESPACE命令详解
2014-04-22 15:43 1455语法描述: CREATE [UNDO] TABLESPA ... -
SGA和PGA推荐配置
2014-01-23 09:07 1278查询SGA和PGA: SQL> show para ... -
oracle用户LANG和NLS_LANG环境变量设置
2014-02-14 14:14 1696export LANG=en_US.UTF-8 NLS_ ... -
几个常用的数据库操作以及视图
2014-02-19 16:48 1597一.查看表空间剩余百分比 SELECT tablespa ... -
orapwd 工具建立密码文件遵守的命名方法
2014-02-19 16:48 918orapwd 工具建立建立的密码文件一定要orapw+实例 ... -
oracle删除数据文件
2014-02-19 16:48 3688在我们详细介绍之前,我们必须说清楚一点:Oracle不提供 ... -
Oracle Undo表空间介绍
2014-02-22 08:53 1477UNDO表空间的作用和管 ... -
ALTER DATABASE 与 ALTER TABLESPACE OFFLINE的区别
2014-02-22 08:52 1043一.DataFile脱机或联机的两种方法: ① ALTE ... -
获取表空间、用户和外键的DDL语句
2013-10-24 16:22 932工作中,需要现场返回所有表空间及用户信息 get_ddl ... -
利用dbms_metadata.get_ddl查看DDL语句
2013-10-24 16:20 1254本文转载,原文地址为:http://czmmiao.itey ... -
临时表空间数据文件的迁移方法
2013-04-28 15:27 1453对于临时表空间数据文件的迁移方法如下:alter tables ... -
表空间数据文件移动或改名操作
2013-04-24 10:23 1132sqlplus /nologSQL> conn /as ... -
Duties of Oracle Database Administrators
2013-03-17 22:47 934The principal responsibility o ...
相关推荐
总结来说,监听配置是数据库管理中的基础工作,理解动态和静态注册的区别以及如何在不同场景下配置,对于优化数据库性能和保证系统稳定性至关重要。通过正确配置,可以确保服务的可发现性,同时增强系统的安全性和可...
总结,Oracle数据库的静态注册和动态注册各有其应用场景。静态注册适用于环境稳定,服务名和实例名固定的场景,配置简单但不灵活。动态注册则适用于需要动态调整服务名或实例名的情况,更便于管理和维护。了解并熟练...
静态注册适用于固定配置,而动态注册则适用于需要动态调整服务和实例信息的环境。理解这两种方式的工作原理对于管理和优化Oracle数据库的连接性能至关重要。在实际应用中,根据系统的具体需求和复杂性,选择合适的...
这里我们将深入探讨两种主要的广播注册方式:静态注册和动态注册,以及它们各自的优缺点。 **1. 静态注册** 静态注册是在AndroidManifest.xml文件中通过标签来定义广播接收器。例如: ```xml ``` 这种...
在AndroidManifest.xml文件中静态注册`SmsReceiver`,或者在需要监听时动态注册。静态注册可以确保即使应用未运行也能接收到广播,但可能会消耗更多资源。动态注册通常在需要时进行,例如在Activity的`onResume()`...
- **静态注册**: 在`listener.ora`文件中直接指定服务名和服务对应的监听器。 **动态注册示例**: 1. **定义`ALL_LISTENER`**: 在`tnsnames.ora`文件中添加一个描述符`ALL_LISTENER`,该描述符包含了所有希望服务...
- **JSP (Java Server Pages)**:一种将静态 HTML 页面和动态 Java 代码结合在一起的技术,用来创建动态网页。 - **Filter**:用于拦截请求和响应的过程,可以在请求到达 Servlet 之前进行预处理,也可以在响应发送...
Oracle数据库的监听器服务可以通过两种方式注册:动态注册和静态注册。 - 动态注册的服务在使用lsnrctl status命令查看状态时显示为ready,表示服务是可用状态。 - 静态注册的服务在使用lsnrctl status命令查看状态...
- Servlet需要在web.xml文件中进行注册和配置,以便服务器能够识别和加载。 4. web.xml配置文件: - web.xml是Tomcat中用于配置Servlet、Listener、Filter等组件的部署描述文件。 - 在web.xml文件中,可以通过...
Spring Boot 支持多种方式来实现 Servlet、Filter 和 Listener 的注册。 ##### 方法一:使用 Bean 注册 1. **自定义 Servlet** ```java public class CustomServlet extends HttpServlet { private static ...
#### 五、总结 - 通过对Jetty源码的深入分析,可以发现其设计的核心理念在于简化Web应用的部署流程,同时保证高性能与灵活性。无论是对于初学者还是有经验的开发者来说,Jetty都提供了强大的工具与框架支持,帮助...
5. **Filter和Listener**:Filter(过滤器)和Listener(监听器)是JavaWeb中的重要组件,可以实现全局的功能,比如权限控制、字符编码转换、日志记录等。在图书书城中,Filter可能用于对用户请求进行预处理,如验证...
在Spring Boot框架中,过滤器(Filter)和监听器(Listener)是两个非常重要的概念,它们可以帮助我们实现一些自定义的处理逻辑,如数据校验、日志记录、请求拦截等。下面将详细讲解这两个概念及其在实际开发中的...
- TypeScript 是 JavaScript 的超集,增加了静态类型系统和现代化的编程特性,如接口、枚举、泛型等。使用 TypeScript 开发 "qiwi-payment-listener" 可以在编码阶段捕获错误,提高代码质量,同时提供更好的代码...
静态部分负责展示网页布局,动态部分通过`<%...%>`、`<%=...%>`、`<jsp:...>`等标签来执行逻辑处理和数据输出。 2. **指令元素**:包括`<%@ page %>`, `<%@ include %>`, `<%@ taglib %>`等,用于配置页面属性、...
总结来说,Laravel的钩子系统是其强大功能和灵活性的核心组成部分,通过事件、中间件、模型事件等多种方式,开发者可以定制化应用程序的行为,确保代码的可维护性和扩展性。通过深入理解和利用这些钩子,可以构建出...
- **SID_LIST_LISTENER**:用于配置监听的静态注册特性,包含数据库服务名、实例名等信息。 - **ADR_BASE_LISTENER**:指定数据库服务的路径。 ##### 3.2 配置过程详解 1. **监听器基础配置**:通过编辑`listener....
总结,Java内部类是一种强大的工具,能够帮助我们更好地组织代码、实现复杂的逻辑和接口。但使用时也需谨慎,避免过度依赖内部类导致代码难以理解和维护。在实际项目中,应根据具体需求选择合适的设计模式。
Servlet是Java编写的服务器端程序,主要用于扩展服务器的功能,处理HTTP请求,而JSP(JavaServer Pages)则是一种视图技术,方便地将静态内容和动态内容结合在一起。下面将详细介绍Servlet和JSP的核心编程概念及应用...