oracle存储过程调试无法进入,oracle存储过程无法调试

时间:2022-08-05 01:19:45

问题:

使用pl/sql developer 调试oracle 存储过程。

在存储过程上点右键,选调试(test),然后按f9(debug)。这是正常的话,那些run、step into等按钮就可以点了,或者点run到断点,或者点step into做单步跟踪。

但是在一个oracle rac双机环境中调试一个存储过程,点f9后有时能继续run或者 step into,有时候pl/sql dev就像死掉了一样,那些按钮都不能点了,下面的状态提示栏中显示“executing”。

原因:

双机采用了负载均衡策略,而调试要启动两个会话,这就有可能被分配到不同的节点上,造成无法调试。

解决办法:

要调试存储过程的开发机器上tnsnames配置单机访问。(说明:服务器是双机,tnsnames配置的时候用实际ip,不要用虚拟的ip)

例如:

RAC1 =(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = 192.0.0.1)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = RAC) # notice the difference(INSTANCE_NAME = RAC1) # betwen this))