Oracle连接问题实例分析

62次阅读
没有评论

共计 2470 个字符,预计需要花费 7 分钟才能阅读完成。

今天丸趣 TV 小编给大家分享一下 Oracle 连接问题实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

  我们知道 Oracle 在启动的时,fork 进程会根据 ORACLE_SID 来创建相关后台进程,而在 Unix 和 Linux 系统中,ORACLE SID 和 ORACLE_HOME 在一起哈希后会得到一个唯一的值作为 SGA 的 key。

  所以我抛出一个蛮有意思的问题,在同一台服务器上,存在 10g,11g 多个 ORACLE_HOME,是可以创建多个同名的 Oracle 实例,而如果在同一个用户下(比如操作系统用户是 oracle),是否可能创建出两个同名的实例来?

  我想你的脑海中已经有了答案。我换一个角度来说明是否可以。通过一个蛮有意思的 DG 配置问题。

  我在使用 RMAN 的 duplicate 搭建备库的时候抛出了下面的一个错误。

RMAN duplicate target database for standby from active database nofilenamecheck;
Starting Duplicate Db at 2017-08-03 10:40:42
RMAN-03002: failure of Duplicate Db command at 08/03/2017 10:40:42
RMAN-05501: aborting duplication of target database
RMAN-06403: could not obtain a fully authorized session
RMAN-04006: error from auxiliary database: ORA-01034: ORACLE not available
ORA-27101: shared memory realm does not exist
Linux-x86_64 Error: 2: No such file or directory

看错误很明显,备库是被启动,找不到内存结构了。

但是实际上查看数据库进程,是没有问题的。

而我根据服务名尝试连接,下面的结果让我大跌眼镜。

sqlplus sys@s2Queuedb as sysdba
SQL*Plus: Release 11.2.0.4.0 Production on Thu Aug 3 10:41:53 2017
Copyright (c) 1982, 2013, Oracle.  All rights reserved.
Enter password:
Connected to an idle instance.

这是哪里的问题呢,是不是实例名有大小写的拆吧呢,在我的印象中似乎没有。那我索性就在这个窗口下尝试启动,没想到还真起来了一个新的实例。

SQL startup nomount
ORACLE instance started.
Total System Global Area 9620525056 bytes
Fixed Size  2261368 bytes
Variable Size  2248150664 bytes
Database Buffers  7348420608 bytes
Redo Buffers  21692416 bytes

你看这下同一个用户下有两个同名的实例了。

$ ps -ef|grep smon|grep -v grep
oracle  43259  1  0 10:39 ?  00:00:00 ora_smon_Queuedb
oracle  43337  1  0 10:44 ?  00:00:00 ora_smon_Queuedb

到了这里,不要以为是 bug,也不要认为以前的这些基础知识都不奏效了。我们梳理一下思路。

首先 ORACLE_SID 是统一的,是同一个,而不同之处就是 ORACLE_HOME 了。而这个数据库环境我只安装了一个版本的数据库环境,所以不存在多个 ORACLE_HOME, 所以这个问题让我很纠结,我们继续来看看 ORACLE_HOME 的情况,可以查看环境变量的值。

$ cat /proc/43259/environ |xargs -0 -n1 |grep ORACLE_HOME
ORACLE_HOME=/U01/app/oracle/product/11.2.0.4

查看另外一个实例的 ORACLE_HOME 变量的值。

$ cat /proc/43337/environ |xargs -0 -n1 |grep ORACLE_HOME
ORACLE_HOME=/home/U01/app/oracle/product/11.2.0.4

到了这里,似乎有了眉目,原来是 ORACLE_HOME 不一样。

而问题到了这里还是有些奇怪,因为 /home/U01 和 /U01 是指向的同一个目录。他们代表的含义是一样的。

lrwxrwxrwx  1 root root  9 Aug  1 17:53 U01 – /home/U0

这个问题到了这里该这么解释呢,我们继续理一下思路。我们在 RMAN 使用 duplicate 的时候是使用 TNS 连接方式的,那么 TNS 连接在连接本地实例的时候指向了另外一个实例(尽管刚开始这个实例不存在),那么本地的连接配置其实还是在 listener.ora 里面。

打开静态注册的内容,这样一看就很清楚了。

SID_LIST_LISTENER =
  (SID_LIST =
  (SID_DESC =
  (GLOBAL_DBNAME = Queuedb)
  (ORACLE_HOME = /home/U01/app/oracle/product/11.2.0.4)
  (SID_NAME = Queuedb)
  )
  )

所以了解了这个问题,我们可以换个思路想想有什么场景可以把这个特点发扬光大,在一些特定的场景中起到神助攻的作用。

至少在之前的数据迁移中,我是使用多个版本的 ORACLE_HOME 来达到同服务器多实例的切换,能够极大的提高数据迁移的效率。

以上就是“Oracle 连接问题实例分析”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,丸趣 TV 小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注丸趣 TV 行业资讯频道。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-15发表,共计2470字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)