`
gzcj
  • 浏览: 289748 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Oracle10g启动及连接问题

阅读更多

前段时间使用oracle10g数据库,因为之前基本不在客户端使用,所以在客户端使用的时候碰到些问题,总结在这里作为记录:

1.环境:

服务端:windowsxp(带防火墙) oracle10g

客户端:windowsxp sqlplus

 

2.连接问题:

在进行连接的时候遇到客户端连不上服务端,经检查发现是windows的防火墙在做怪,于是,修改防火墙的例外:

添加了端口:1521(连接,连不上)

后来发现还要添加程序:oracle.exe和TNSLSNR.EXE

 

进行连接,ok。

 

 

3.从客户端shutdown数据库,然后在startup,发现数据库起不来啊,后来发现是动态注册的问题。

修改动态注册为静态注册,将listner.ora,改为如下形式即可:

SID_LIST_LISTENER = 

(SID_LIST = 

(SID_DESC = 

(SID_NAME = PLSExtProc) 

(ORACLE_HOME = D:\oracle\product\10.2.0\db_1) 

(PROGRAM = extproc) 

) 
#以下是静态注册的内容
(SID_DESC = 

(GLOBAL_DBNAME =orcl) #数据库名

(ORACLE_HOME = D:\oracle\product\10.2.0\db_1) 

(SID_NAME =orcl) #数据库sid

) 

) 

 修改完listner.ora后,重启服务。

从客户端连接数据库:

SQL>CONN X/XX@XXX  AS SYSDBA

x:用户名

xx:密码

xxx:客户端连接服务端的连接(即tnsnames.ora中的字符串)

SQL>SHUTDOWN IMMEDIATE

提示shutdown成功

SQL>STARTUP

startup成功


 

 

 

这里顺便介绍一下静态注册和动态注册(网上找的):

 

一、什么是注册?

注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。

在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)

相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。

 

二、静态注册

静态注册就是实例启动时读取listener.ora文件的配置,将实例和服务注册到监听程序。无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。

静态注册时,listener.ora中的GLOBAL_DBNAME向外提供服务名,listener.ora中的SID_NAME提供注册的实例名。

listener.ora中的内容大致如下:

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC =

(SID_NAME = PLSExtProc)

(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)

(PROGRAM = extproc)

)

)

 


三、动态注册

动态注册是在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 ;

采取动态注册方法时,listener.ora中的内容如下:

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC =

(SID_NAME = PLSExtProc)

(ORACLE_HOME = D:\oracle\product\10.2.0\db_1)

(PROGRAM = extproc)

)

)

 

可选择的是,您可以在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)和负载平衡。

分享到:
评论

相关推荐

    Oracle 10G 的dbconsole 无法启动问题 之彻底解决 方法

    ### Oracle 10G dbconsole 无法启动问题及其彻底解决方法 #### 一、问题背景与现象 在从Oracle 9i迁移至10g的过程中,可能会遇到dbconsole(即Database Control,简称“em”)无法正常启动的问题。通常情况下,...

    Delphi7 ado 连接远程oracle11g

    ### Delphi7 ADO 连接远程 Oracle11g 的详细步骤及注意事项 #### 一、概述 本文档旨在提供一套完整的解决方案,帮助用户在 Delphi7 环境下通过 ADO 连接到远程 Oracle11g 数据库。整个过程涉及到服务器端的安装与...

    Oracle10g客户端详细安装手册

    本手册将详细介绍Oracle10g客户端在Windows操作系统下的安装步骤及过程中需要注意的关键点。 #### 二、准备工作 1. **下载安装包**:首先需要从指定的网络位置下载Oracle10g客户端的安装文件。根据提供的链接“\\...

    Oracle10g 在windows上的安装

    1. **启动安装程序**:插入Oracle 10g安装光盘后,如果没有自动启动安装程序,可以通过双击光盘中的`setup.exe`来启动安装。 2. **选择安装类型**:根据实际需求选择合适的安装类型(企业版、标准版、个人版或定制...

    windowsServer2008_64位安装oracle10G全过程

    本文档详细记录了在Windows Server 2008 64位环境下安装Oracle 10G数据库的过程,包括准备工作、安装步骤及常见问题解决方法。通过遵循这些步骤,可以有效避免安装过程中可能遇到的问题,确保Oracle 10G数据库的成功...

    oracle10g或11g通过dblink访问sql server数据库

    ### Oracle 10g 或 11g 通过 DBLink 访问 SQL Server 数据库 #### 概述 本文档详细介绍了如何在Oracle 10g或11g环境中使用DBLink来访问SQL Server数据库的方法。这种方法对于那些习惯于使用Oracle进行数据库操作的...

    win7下安装oracle10g

    4. **环境准备**:确保系统已安装.NET Framework 2.0及更高版本,因为Oracle 10g需要此框架支持。 #### 三、修改配置文件 1. **refhost.xml**:这是一个配置文件,用于指定操作系统版本等信息。根据提供的XML代码...

    oracle 10g 下载地址大全

    Oracle 10g 下载地址大全 Oracle 10g 是 Oracle 公司推出的关系数据库管理系统的第十个主要版本。它提供了许多新功能和改进,旨在提高数据库的性能、可靠性和安全性。 Oracle 10g 分为 Enterprise Edition、...

    Oracle 10g 安装配置

    "Oracle 10g 安装配置" Oracle 10g 安装配置是一个复杂的过程,需要了解 Oracle 应用服务器 10g 的基本概念和安装要求。下面将从硬件要求、软件要求、数据库安装和客户端配置等方面详细介绍 Oracle 10g 安装配置的...

    tomcat 与 oracle db 10g xe 连接

    ### Tomcat 与 Oracle DB 10g XE 连接 #### 一、概述 在实际的应用场景中,经常需要让应用服务器如Tomcat与数据库进行交互,以实现数据的存储与读取功能。本篇文章将详细介绍如何配置Tomcat 6与Oracle Database 10...

    Linux下设置oracle 10g 服务以及实例自动启动方法

    本教程将详细解释如何设置Oracle 10g服务以及实例在Linux上实现自动启动,确保系统启动时数据库能够自动运行。 **一、Oracle 10g服务与实例** 1. **服务(Service)**:在Linux中,服务是指后台运行的程序,通常...

    linux下oracle 10g的启动与关闭

    ### 一、Oracle 10g启动流程 #### 1. 设置环境变量 在启动Oracle数据库之前,首先需要确保环境变量正确设置,这通常意味着定义`$ORACLE_HOME`。`$ORACLE_HOME`是Oracle产品的安装目录,对于Oracle 10g而言,它包含...

    oracle10g透明网关连接SqlServer2008

    Oracle 10g 透明网关连接到 SQL Server 2008 是一种技术,它允许用户在 Oracle 数据库环境中无缝地访问 SQL Server 数据库,仿佛它们是同一个系统的一部分。透明网关使得数据集成和跨数据库操作变得简单,无需编写...

    Oracle 10g联机文档

    通过这份文档,用户可以学习如何安装、配置、管理、优化以及解决Oracle 10g数据库中的各种问题。 Oracle 10g联机文档主要包括以下几个部分: 1. **安装与配置**:这部分内容详细介绍了如何在不同操作系统平台上...

    启动、关闭 oracle11g bat 命令

    - `net start OracleOraDb11g_home1TNSListener`:启动Oracle的网络监听器,负责监听并接受来自客户端的连接请求。 - `net start OracleServiceORCL`:启动名为ORCL的数据库实例,这是Oracle数据库的核心服务。 - `...

    Oracle 10g 安装(Windows下)

    Oracle 10g是一款经典的关系型数据库管理系统,尤其在企业级应用中有着广泛的应用。本文将详细介绍在Windows操作系统下如何安装Oracle 10g。在安装过程中,我们需要了解一些关键概念和技术,包括数据库架构、安装...

Global site tag (gtag.js) - Google Analytics