溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Linux 環(huán)境下, ORACLE 監(jiān)聽(tīng)啟動(dòng)慢的問(wèn)題分析

發(fā)布時(shí)間:2020-07-12 07:09:06 來(lái)源:網(wǎng)絡(luò) 閱讀:1964 作者:背向天堂 欄目:關(guān)系型數(shù)據(jù)庫(kù)

    虛擬機(jī)環(huán)境,OEL7.2, ORACLE 12.1。 重啟主機(jī)后,發(fā)現(xiàn)監(jiān)聽(tīng)程序啟動(dòng)好像將近1分鐘。


下面是分析過(guò)程:


執(zhí)行監(jiān)聽(tīng)啟動(dòng)操作,會(huì)hang起來(lái)一段時(shí)間,最終監(jiān)聽(tīng)啟動(dòng)成功

[oracle@sky-oel7 ~]$ 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

啟動(dòng)耗時(shí)40秒。


指定監(jiān)聽(tīng)的日志等級(jí)為16

[oracle@sky-oel7 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


重新啟動(dòng)監(jiān)聽(tīng)程序,日志

[oracle@sky-oel7 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

[oracle@sky-oel7 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

沒(méi)有更多的可用信息。


通過(guò)strace進(jìn)行進(jìn)程啟動(dòng)信息分析

[oracle@sky-oel7 ~]$ 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)

上面的信息看出,是由于地址解析失敗造成網(wǎng)絡(luò)超時(shí)。


這些地址都是安裝時(shí),自動(dòng)產(chǎn)生的DNS地址信息,由于環(huán)境發(fā)生變化,DNS地址不同,造成訪問(wèn)操作

[root@sky-oel7 ~]# cat /etc/resolv.conf 

# Generated by NetworkManager

search workgroup

nameserver 172.24.97.1

nameserver 192.168.191.1


屏蔽這些地址后,listener啟動(dòng)正常。


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI