Oracle 12.2监听无法启动解决一例

简介:

在自己的虚拟机的做实验,突然发现使用PL/SQL Developer无法连接到数据库,报错ORA-12514,说是监听没有启动。

先介绍虚拟机一下环境:redhat7.2+GI 12.2.0.1+Oracle 12.2.0.1,为了测试12.2的ASM特性安装了GI。平时监听程序默认是开启启动的。但是今天不知道为什么没有启动。使用crsctl查看资源状态:发现监听的状态确实是OFFLINE状态

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
[root@rhel7 .oracle] # crsstat
--------------------------------------------------------------------------------
Name           Target  State        Server                   State details       
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.DATA.dg
                ONLINE  ONLINE       rhel7                    STABLE
ora.LISTENER.lsnr
                ONLINE  OFFLINE      rhel7                    STABLE
ora.asm
                ONLINE  ONLINE       rhel7                    Started,STABLE
ora.ons
                OFFLINE OFFLINE      rhel7                    STABLE
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.cssd
       1        ONLINE  ONLINE       rhel7                    STABLE
ora.diskmon
       1        OFFLINE OFFLINE                               STABLE
ora.driver.afd
       1        ONLINE  ONLINE       rhel7                    STABLE
ora.evmd
       1        ONLINE  ONLINE       rhel7                    STABLE
ora.ora12c.db
       1        ONLINE  ONLINE       rhel7                    Open,HOME= /u01/app/o
                                                              racle /product/12 .2 /d
                                                              b_home1,STABLE
--------------------------------------------------------------------------------

尝试手动启动监听,依然报错:

1
2
3
4
5
[grid@rhel7 ~]$ srvctl start listener
PRCR-1079 : Failed to start resource ora.LISTENER.lsnr
CRS-5016: Process  "/u01/app/grid/bin/lsnrctl"  spawned by agent  "ORAAGENT"  for  action  "start"  failed: details at  "(:CLSN00010:)"  in  "/u01/app/12.2/grid/diag/crs/rhel7/crs/trace/ohasd_oraagent_grid.trc"
CRS-5016: Process  "/u01/app/grid/bin/lsnrctl"  spawned by agent  "ORAAGENT"  for  action  "start"  failed: details at  "(:CLSN00010:)"  in  "/u01/app/12.2/grid/diag/crs/rhel7/crs/trace/ohasd_oraagent_grid.trc"
CRS-2674: Start of  'ora.LISTENER.lsnr'  on  'rhel7'  failed

根据提示查看trc文件,看到如下报错:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
LSNRCTL  for  Linux: Version 12.2.0.1.0 - Production on 15-NOV-2017 20:03:28
 
Copyright (c) 1991, 2016, Oracle.  All rights reserved.
 
Starting  /u01/app/grid/bin/tnslsnr : please wait...
 
TNSLSNR  for  Linux: Version 12.2.0.1.0 - Production
System parameter  file  is  /u01/app/grid/network/admin/listener .ora
Log messages written to  /u01/app/12 .2 /grid/diag/tnslsnr/rhel7/listener/alert/log .xml
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=rhel7)(PORT=1521)))
Error listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1521)))
TNS-12555: TNS:permission denied
  TNS-12560: TNS:protocol adapter error
   TNS-00525: Insufficient privilege  for  operation
    Linux Error: 1: Operation not permitted
 
Listener failed to start. See the error message(s) above...

看到Insufficient privilege for operation这个字样觉得很纳闷,怎么会权限不足呢,于是尝试用root直接启动监听,依然报错:

1
2
3
4
5
6
7
8
9
10
11
12
[root@rhel7 .oracle] # lsnrctl start
 
LSNRCTL  for  Linux: Version 12.2.0.1.0 - Production on 15-NOV-2017 20:22:30
 
Copyright (c) 1991, 2016, Oracle.  All rights reserved.
 
Starting  /u01/app/grid/bin/tnslsnr : please wait...
 
TNS-12546: TNS:permission denied
  TNS-12560: TNS:protocol adapter error
   TNS-00516: Permission denied
    Linux Error: 13: Permission denied

于是各种百度,下面把百度到内容列出来,可能会对看此文的同学有用,但是对我这种情况没有用:

主要是说 /var/tmp/.oracle、/tmp/.oracle 这两个目录的权限访问问题。 进入 一看,我的/var/tmp/.oracle权限 没问题,而/tmp/.oracle压根就没有这个文件。

于是直接查MOS,看有没有相关的文档,找到两篇文档:

Starting the Listener Fails With: TNS-12557 or TNS-12555: TNS:Permission Denied (文档 ID 343253.1)

Listener Fails To Start With IPC Permission Errors (TNS-12546 TNS-12555 TNS-00516 TNS-00525) (文档 ID 434062.1)

对比了文档中列出的问题,跟我的情况也不一相,看到最后发现这样一句话:

4. If you find that there are no adapters linked or they have errors (such as "Permission denied") then issue a "relink all"
Reference:
Doc ID 1467060.1

于是只有用这种方法来试试了,由于crs使用的是grid home下的监听命令所以对grid home做relink all操作。可是又出现报错:

1
2
3
4
5
6
7
[grid@rhel7 bin]$ relink all
   The Oracle home  in  which  you are running this relinking tool does not 
have proper write permissions. Please run this relink script as the same
user  who  owns the Oracle home and ensure that the Oracle home has the
permissions from the original installation.
   If this is a Grid Infrastructure home, please refer to the 
documentation  for  the proper steps to relink and apply oneoff patches.

意思是说权限不足,使用root执行,又报错说不能用root执行

1
2
[root@rhel7 bin] # relink all
The relink script cannot be run as root.

又查看grid home目录权限

1
2
3
[root@rhel7 app] # ls -ld grid
total 8
drwxr-x---  84 root   oinstall 4096 Jul 18 20:26 grid

原来owner是root,怪不得第一次执行不成功,修改owner(应该直接chmod也可以,这里没有做测试),重新执行relink all

1
2
3
[root@rhel7 app] # chown grid grid
[grid@rhel7 ~]$ relink all
writing relink log to:  /u01/app/grid/install/relink .log

成功后再次启动监听,启动成功。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
[grid@rhel7 ~]$ lsnrctl start
 
LSNRCTL  for  Linux: Version 12.2.0.1.0 - Production on 15-NOV-2017 20:50:59
 
Copyright (c) 1991, 2016, Oracle.  All rights reserved.
 
Starting  /u01/app/grid/bin/tnslsnr : please wait...
 
TNSLSNR  for  Linux: Version 12.2.0.1.0 - Production
System parameter  file  is  /u01/app/grid/network/admin/listener .ora
Log messages written to  /u01/app/12 .2 /grid/diag/tnslsnr/rhel7/listener/alert/log .xml
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=rhel7)(PORT=1521)))
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521)))
 
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=rhel7)(PORT=1521)))
STATUS of the LISTENER
------------------------
Alias                     LISTENER
Version                   TNSLSNR  for  Linux: Version 12.2.0.1.0 - Production
Start Date                15-NOV-2017 20:51:00
Uptime                    0 days 0 hr. 0 min. 0 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File    /u01/ app/grid/network/admin/listener .ora
Listener Log File          /u01/app/12 .2 /grid/diag/tnslsnr/rhel7/listener/alert/log .xml
Listening Endpoints Summary...
   (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=rhel7)(PORT=1521)))
   (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521)))
The listener supports no services
The  command  completed successfully

至次问题解决。



      本文转自hbxztc 51CTO博客,原文链接:http://blog.51cto.com/hbxztc/1982138,如需转载请自行联系原作者




相关文章
|
4月前
|
Oracle 关系型数据库 Linux
Oracle设置监听之Navicat的锅
Oracle设置监听之Navicat的锅
31 0
|
11月前
|
监控 Oracle 网络协议
干货速看!CentOS7+Oracle 19c安装并开启IPv6监听,带你一文打尽。
近日,工信部印发了关于贯彻落实《推进IPv6规模部署行动计划》的通知,额。。。不好意思,跑题了!其实也没有跑题,本篇就是想要讲跟IPV6有关的东西。现在很多最新版的组件都默认支持IPV6了,比如Nginx、PHP、MySQL等等。那么本篇专门讲解一下Oracle 19C如何开启对IPV6的支持,从安装到配置、到IPV6监听的配置,一文打尽。
289 0
|
Oracle 安全 关系型数据库
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 下
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 下
190 0
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务   下
|
SQL Oracle 关系型数据库
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 上
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 上
398 0
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务   上
|
网络协议 Oracle 关系型数据库
Oracle rac不能监听public ip
Oracle rac不能监听public ip
233 0
|
Oracle 关系型数据库
oracle学习21-修改为静态监听
oracle学习21-修改为静态监听
79 0
oracle学习21-修改为静态监听
|
Oracle 关系型数据库
oracle学习3-配置监听
oracle学习3-配置监听
92 0
oracle学习3-配置监听
|
Oracle 关系型数据库
oracle学习24-数据文件设置自扩展和监听日志文件过大处理
oracle学习24-数据文件设置自扩展和监听日志文件过大处理
197 0
|
Oracle 关系型数据库
oracle学习49-监听服务设置开机自启,不用一直配置监听
oracle学习49-监听服务设置开机自启,不用一直配置监听
87 0
oracle学习49-监听服务设置开机自启,不用一直配置监听
|
Oracle 关系型数据库
oracle学习33-无监听程序
oracle学习33-无监听程序
93 0
oracle学习33-无监听程序

推荐镜像

更多