Linux 环境下, ORACLE 监听启动慢的问题分析

虚拟机环境,OEL7.2, ORACLE 12.1。 重启主机后,发现监听程序启动好像将近1分钟。

下面是分析过程:

执行监听启动操作,会hang起来一段时间,最终监听启动成功

[[email protected] ~]$ lsnrctl start

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=sky-oel7)(PORT=1521)))

STATUS of the LISTENER

------------------------

Alias                     LISTENER

Version                   TNSLSNR for Linux: Version 12.1.0.2.0 - Production

Start Date                12-JAN-2016 16:42:57

Uptime                    0 days 0 hr. 0 min. 40 sec

启动耗时40秒。

指定监听的日志等级为16

[[email protected] trace]$ cat /oracle/app/oracle/product/12.1.0/dbhome_1/network/admin/listener.ora

# listener.ora Network Configuration File: /oracle/app/oracle/product/12.1.0/dbhome_1/network/admin/listener.ora

# Generated by Oracle configuration tools.

LISTENER =

(DESCRIPTION_LIST =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = sky-oel7)(PORT = 1521))

)

)

TRACE_LEVEL_LISTENER=16


重新启动监听程序,日志

[[email protected] trace]$ tail -f listener.log

Log messages written to /oracle/app/oracle/diag/tnslsnr/sky-oel7/listener/alert/log.xml

Trace information written to /oracle/app/oracle/diag/tnslsnr/sky-oel7/listener/trace/ora_4179_140717186082304.trc

Trace level is currently 16

Started with pid=4179

Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=sky-oel7)(PORT=1521)))

TIMESTAMP * CONNECT DATA [* PROTOCOL INFO] * EVENT [* SID] * RETURN CODE

WARNING: Subscription for node down event still pending

12-JAN-2016 16:10:14 * (CONNECT_DATA=(CID=(PROGRAM=)(HOST=sky-oel7)(USER=oracle))(COMMAND=status)(ARGUMENTS=64)(SERVICE=LISTENER)(VERSION=202375680)) * status * 0

[[email protected] admin]$ vi /oracle/app/oracle/diag/tnslsnr/sky-oel7/listener/trace/ora_4179_140717186082304.trc

2016-01-12 16:09:34.211259 : nttcnp:binding an address to a socket.

2016-01-12 16:09:34.211275 : nttcnp:listening on a bound socket (queue size = 128).

2016-01-12 16:09:34.211324 : nttcnp:getting sockname

2016-01-12 16:09:34.211342 : nttcnp:getting peername

2016-01-12 16:09:34.211355 : nttcnp:exit

2016-01-12 16:09:34.211368 : snlinGetAddrInfo:entry

2016-01-12 16:10:14.256096 : snlinGetAddrInfo:getaddrinfo() failed with error -3

2016-01-12 16:10:14.256193 : snlinGetAddrInfo:exit

2016-01-12 16:10:14.256215 : nttcon:exit

2016-01-12 16:10:14.256241 : nsopen:transport is open

2016-01-12 16:10:14.256261 : nsoptions:entry

没有更多的可用信息。

通过strace进行进程启动信息分析

[[email protected] ~]$ strace -f -t -o ~/listener.trc lsnrctl start

查看strace日志信息

5042  16:42:57 socket(PF_INET, SOCK_DGRAM|SOCK_NONBLOCK, IPPROTO_IP) = 13

5042  16:42:57 connect(13, {sa_family=AF_INET, sin_port=htons(53), sin_addr=inet_addr("172.24.97.1")}, 16) = 0

5042  16:42:57 poll([{fd=13, events=POLLOUT}], 1, 0) = 1 ([{fd=13, revents=POLLOUT}])

5042  16:42:57 sendto(13, ":\26\1\0\0\1\0\0\0\0\0\0\10sky-oel7\tworkgroup\0"..., 36, MSG_NOSIGNAL, NULL, 0) = 36

5042  16:42:57 poll([{fd=13, events=POLLIN}], 1, 5000) = 0 (Timeout)

5042  16:43:02 socket(PF_INET, SOCK_DGRAM|SOCK_NONBLOCK, IPPROTO_IP) = 14

5042  16:43:02 connect(14, {sa_family=AF_INET, sin_port=htons(53), sin_addr=inet_addr("192.168.191.1")}, 16) = 0

5042  16:43:02 poll([{fd=14, events=POLLOUT}], 1, 0) = 1 ([{fd=14, revents=POLLOUT}])

5042  16:43:02 sendto(14, ":\26\1\0\0\1\0\0\0\0\0\0\10sky-oel7\tworkgroup\0"..., 36, MSG_NOSIGNAL, NULL, 0) = 36

5042  16:43:02 poll([{fd=14, events=POLLIN}], 1, 5000) = 0 (Timeout)

上面的信息看出,是由于地址解析失败造成网络超时。

这些地址都是安装时,自动产生的DNS地址信息,由于环境发生变化,DNS地址不同,造成访问操作

[[email protected] ~]# cat /etc/resolv.conf

# Generated by NetworkManager

search workgroup

nameserver 172.24.97.1

nameserver 192.168.191.1

屏蔽这些地址后,listener启动正常。

时间: 2024-07-30 22:25:40

Linux 环境下, ORACLE 监听启动慢的问题分析的相关文章

全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装配置系统环境安装linux ,所有服务都不选择,只是选择安装开发工具,不要安装防火墙(当然也可以在后面关闭) 打开终端,执行如下命令,检查安装包,没有的都要安装 make, glibc, libaio compat-libstdc++, compat-gcc-34, compat-gcc-34-c++, gc

oracle 监听启动错误

oracle 监听启动错误 | 进击的大黄 盒子 盒子 博客 分类 标签 友链 关于 RSS 搜索 上午启动应用连接测试数据库的时候一直显示连接已满,然后上网查需要修改数据库最大连接数SQL> alter system set processes=1000 scope=spfile;然后重启数据库,但是 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ? /Users/huangrupeng >ssh [email pro

全世界最详细的图形化VMware中linux环境下oracle安装(二)【weber出品必属精品】

<ORACLE 10.2.05版本的升级补丁安装> 首先我们解压 $ unzip p8202632_10205_LINUX.zip 解压后我们会发现多出了个文件夹,他是:Disk1,进入Disk1.然后执行安装: $ ./runInstaller 执行脚本 # /u01/app/oracle/10.2.0/db_1/root.sh Running Oracle 10g root.sh script... The following environment variables are set a

Linux环境下Oracle数据库启动停止命令

切换root至oracle数据库账号 su – oracle 查看数据库服务状态: ps -ef |grep oracle netstat –an|grep 1521 查看数据库监听状态: [[email protected] ~]$ lsnrctl status LSNRCTL for Linux: Version 11.2.0.1.0 - Production on 25-NOV-2016 03:36:45 Copyright (c) 1991, 2009, Oracle. All righ

oracle监听启动

1:在root用户下输入su - oracle 切换到oracle用户 2:在oracle用户下输入:sqlplus /nolog 3:进入oracle下:conn /as sysdba 4:停掉数据库oracle: shutdown (启动用startup) 5:然后输入:quit退出 6:停用监听:lsnrctl stop 7:启动监听:lsnrctl start 8:再执行步骤2~4启动数据库:startup

oracle 监听启动、停止、查看命令

1.su oracle 然后启动监听器 1.lsnrctl start  会看到启动成功的界面; 1.lsnrctl stop  停止监听器命令. 1.lsnrctl status  查看监听器命令. oracle数据库的安全包含两部分: 1.一部分是os的安全2.网络的安全3.oracle软件本身的安全 os的安全依赖相应的操作系统及管理员的技术水平,我们这里只谈谈oracle的安全 我了解的oracle软件的安全包含: 1.更改oracle的默认监听端口号 2.给监听器加密码 3.oracl

Oracle监听启动无法连接

现象 远程客户端toad连接,卡死没有反应.oracle服务器端使用 tsping {ip地址} 提示无法连接. 按照提示查询相应问题,提示可能配置问题,检查listener.ora(路径F:\app\Administrator\product\11.2.0\dbhome_1\NETWORK\ADMIN\listener.ora)路径按照实际安装路径查看; 检查配置文件配置 (ADDRESS = (PROTOCOL = TCP)(HOST = HOSTNAME)(PORT = 1521)) 配置

linux 如何开启oracle监听

用oracle用户登录 su oracle sqlplus /nolog --登录sqlplus connect /as sysdba --连接数据库 startup --启动数据库 exit    ---退出sqlplus cd $ORACLE_HOME/bin lsnrctl start ---启动监听 原文地址:https://www.cnblogs.com/dixuemei/p/10825698.html

Oracle监听启动-ORA-12541: TNS: 无监听程序

windows经常遇到TNS无监听问题,首先排查 $ORACLE_BASE/diag/tnslsnr/机器名/listener/trace 下的listenter.log是否达到4g 如果达到4g 解决办法如下 1.cmd  ---->     lsnrctl stop 2.listener.log重命名 3.cmd ---> lsnrctl start 5.查看监听服务状态  lsnrctl status 原文地址:https://www.cnblogs.com/yang6/p/113873