ora-12516 TNS 监听程序找不到符合协议堆栈要求的可用处理程序

ORA-12516: TNS: 监听程序找不到符合协议堆栈要求的可用处理程

 

 

今天测试的同事发现报 ora-12516的错误,基于这个分析,一般有两个原因,一个是session数不够
再有一个就是客户端和服务端建立连接的时候不稳定所引起的,我现在的服务端是oracle10g r2,而
客户端是oracle11i,结果当连接数大的时候,就会报ora-12516的错误

 

解决方法:1.针对第一个原因就是修改连接数的限制
            sql > alter system set processes=300 #### 改的大点

   然后reboot数据库,使其生效

          2.针对第二个原因,我的个人解决方法是,把tns的动态注册改为静态注册(我目前遇到的错误是这么解决的)
     把global_name和sid_name 都写到linster。ora文件中

 

 

备注说明:

 

 

一、什么是注册?

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

 

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

 

  相当于是这样:在数据库服务器和客户端之间有一监听程序(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:oracleproduct10.2.0db_1)
(PROGRAM = extproc)
)
(SID_DESC =
(GLOBAL_DBNAME =orcl)
(ORACLE_HOME = D:oracleproduct10.2.0db_1)
(SID_NAME =orcl)
)
(SID_DESC =
(GLOBAL_DBNAME =orcl1)
(ORACLE_HOME = D:oracleproduct10.2.0db_1)
(SID_NAME =orcl)
)
)

  该文件表明数据库是单实例的,实例名为orcl,向外提供了两个服务:orcl和orcl1

 

  三、动态注册

  动态注册是在instance启动的时候PMON进程根据init.ora中的instance_name,service_names两个参数将实例和
    服务动态注册到listener中。

 

  首先要在init.ora中指定instance_name,service_names两个参数的值。在sqlplus下通过show parameter servi
    ce_names 和show parameter instance_name可以查看这两个参数的值。

 

  注册到监听器中的实例值从init.ora文件中的instance_name参数取得。如果该参数没有设定值,那么它将取ini
    t.ora文件中的db_name的值。

 

  注册到监听器中的服务值从init.ora文件中的参数service_names取得。如果该参数没有设定值,数据库将拼接i
    nit.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:oracleproduct10.2.0db_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)和负载平衡。


转载:http://blog.csdn.net/wyzxg/article/details/3978285

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ORA-12514错误表示TNS监听程序无法识别当前请求的服务名称。这可能是因为服务名称不存在或TNS监听程序未正确配置。要解决此问题,您可以检查TNS监听程序的配置文件,确保服务名称正确配置并且监听程序正在运行。您还可以尝试重新启动TNS监听程序以解决此问题。 ### 回答2: ORA-12514错误提示意味着Oracle客户端无法连接到Oracle服务器。具体而言,处于客户端一侧的TNS监听程序无法识别所请求的连接标识符,这可能会是Oracle实例名称、主机名称或端口号等方面出现问题。 出现ORA-12514错误可能有多种原因,其中包括: 1. Oracle实例名称错误:如果TNS监听程序无法识别客户端比赛中请求的Oracle实例名称,则会弹出ORA-12514错误。 2. 监听程序未启动:如果TNS监听程序未在所需端口上运行,则无法识别客户端连接请求。 3. 主机名或IP地址错误:客户端可能无法确定正确的Oracle数据库服务器名称或IP地址,这可能会导致出现ORA-12514错误。 4. 网络连接问题:网络故障可能导致ORA-12514错误,这可能是由于路由不正确、安全策略或其他网络问题导致的。 解决ORA-12514错误的方法有以下几种: 1. 验证Oracle实例名称和监听程序是否正确:在客户端上手动验证Oracle实例名称和监听程序名称是否正确,确保它们与服务端一致。 2. 启动TNS监听服务:使用相应命令启动TNS监听服务,并确保其在所需端口上运行。 3. 验证主机名或IP地址正确:在客户端上验证主机名或IP地址是否正确,确保它们与服务端相同。 4. 检查网络连接:在本地机器和数据库服务器之间进行一些网络检查,确保网络连接的信息正确无误。 总之,ORA-12514是一个常见的Oracle数据库错误,可能由多种原因引起。解决此问题的最佳方法是仔细审查客户端和服务器之间的所有连接参数,并在客户端上手动验证所有连接参数。 ### 回答3: ORA-12514错误是Oracle数据库中常见的错误之一,通常是由于监听程序无法识别或不到指定的服务名或数据库实例名所导致的。这种类型的错误一般是由于以下几个原因引起的。 1.服务名或数据库实例名拼写错误 在Oracle数据库中,每个数据库都有一个唯一的服务名或数据库实例名。如果在连接字符串中输入错误的服务名或数据库实例名,则监听程序将无法识别它们,并显示ORA-12514错误。因此,在连接Oracle数据库之前,应该确认输入的服务名或数据库实例名是否正确。 2.监听程序未启动或配置错误 确保监听程序正在运行,并且所需的监听器已在监听程序的配置文件(listener.ora)中正确声明。另外,确保监听程序的版本与Oracle数据库版本兼容。如果监听程序未启动或配置错误,Oracle数据库将无法使用监听程序中声明的服务名或数据库实例名,并显示ORA-12514错误。 3.防火墙或网络故障 防火墙或网络故障可能导致监听程序无法到数据库实例,从而导致ORA-12514错误。如果发现防火墙或网络故障,应该检查防火墙或网络设置是否正确,并尝试重新启动监听程序。 4.Oracle数据库实例未启动 如果Oracle数据库实例未启动,则监听程序将无法到数据库实例,并显示ORA-12514错误。确保Oracle数据库实例已启动,并且所需的服务名已注册到监听程序中。 总之,ORA-12514错误是由于监听程序无法识别或不到指定的服务名或数据库实例名所导致的。要解决此错误,需要确认输入的服务名或数据库实例名是否正确、监听程序是否已正确配置、防火墙或网络是否设置正确,以及Oracle数据库实例是否已启动。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值