Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

ORA-12516: TNS:listener could not find available handler with matching protocol stack

테스트용으로 설치해 두었던 Oracle XE 서버를 재설치한 이후로, 희한한 현상이 발생했습니다. 동일한 클라이언트 측 응용 프로그램 환경임에도 불구하고 이번에는 다음과 같은 오류가 발생하는 것이었습니다.

[Oracle.DataAccess.Client.OracleException] ORA-12516: TNS:listener could not find available handler with matching protocol stack
   at Oracle.DataAccess.Client.OracleException.HandleErrorHelper(Int32 errCode, OracleConnection conn, IntPtr opsErrCtx, OpoSqlValCtx* pOpoSqlValCtx, Object src, String procedure)
   at Oracle.DataAccess.Client.OracleException.HandleError(Int32 errCode, OracleConnection conn, IntPtr opsErrCtx, Object src)
   at Oracle.DataAccess.Client.OracleConnection.Open()
   at WebSiteTest.odpnet20test.Page_Load(Object sender, EventArgs e) in d:\...[생략]...\odpnet20test.aspx.cs:line 176
   at System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e)
   at System.Web.UI.Control.LoadRecursive()
   at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)

사실, 간단한 부하 테스트용으로 구성한 시스템이라서 쿼리도 간단하고 서버 환경도 아래의 글에 설명했던 hr 계정 활성화 정도밖에는 없는 상태였습니다.

.NET 응용 프로그램에서 Oracle XE 사용
; https://www.sysnet.pe.kr/2/0/821

ODP.NET을 이용한 웹 페이지를 여러 서버에 두었는데, 무작위로 특정 서버에서만 발생했습니다. 재미있게도, 일단 오류가 발생하는 웹 서버는 계속 발생하는데 만약 그 와중에 다른 서버를 내리면 더 이상 오류가 발생하지 않았습니다. 이런 현상으로 볼 때, 해당 서버의 ODP.NET 구성이 잘못된 것 같지는 않았습니다.

어쨌든, 검색을 해서 찾은 아래 글의 문답을 보면,

Thread: TNS:listener could not find available handler witht matching protocol stack 
; http://forums.oracle.com/forums/thread.jspa?threadID=360226&tstart=-1

"the processes parameter is set to 200"으로 바꾸어서 해결했다고 나오는데... ^^; 어떻게 설정해야 하는지 구체적인 방법이 없더군요. 그래서 좀 더 검색을 해보니, 아래의 글이 나오는데,

ORA-12516: TNS:리스너가 프로토콜 스택과 일치하는 처리기를 찾을 수 없습니다
; http://rothmans.wordpress.com/2009/10/20/ora-12516-tns%EB%A6%AC%EC%8A%A4%EB%84%88%EA%B0%80-%ED%94%84%EB%A1%9C%ED%86%A0%EC%BD%9C-%EC%8A%A4%ED%83%9D%EA%B3%BC-%EC%9D%BC%EC%B9%98%ED%95%98%EB%8A%94-%EC%B2%98%EB%A6%AC%EA%B8%B0%EB%A5%BC-%EC%B0%BE/

애석하게도 위의 글에 나온 "job_queue_processes" 값 변경은 도움이 안 됐습니다. 아마도 위의 2개의 글에서 나온 "processes"가 같은 것이 아니라는 판단하에, 처음의 "processes" 파라미터 값을 변경하기 위한 방법을 찾아보았습니다.

Oracle XE "Processes" Parameter 
; http://sriki77.blogspot.com/2008/11/oracle-xe-processes-parameter.html

위의 글대로 리소스 점유율을 확인하기 위해 http://127.0.0.1:8080/apex에 접속해서 명령을 내렸는데 다음과 같은 결과가 나왔습니다.

select * from v$resource_limit where resource_name in ('processes','sessions');

RESOURCE_NAME CURRENT_UTILIZATION MAX_UTILIZATION INITIAL_ALLOCATION LIMIT_VALUE 
processes 39 40 40 40 
sessions 47 47 49 49 

아하~~~ 이제야 해답이 나온 것 같습니다. 위의 "processes" 값을 조정하면 된다는 것이군요. 문제는 "processes" 값을 변경하기 위한 명령을 내려야 하는데, 이 과정에서 또다시 시간을 소비하게 되었습니다.

C:\oraclexe\app\oracle\product\10.2.0\server\BIN\sqlplus.exe를 실행하고 계정과 암호를 입력하는데... 웬일인지 SYSTEM 계정으로의 로그인이 계속 거부되는 것이었습니다.

SQL*Plus: Release 10.2.0.1.0 - Production on 목 4월 7 00:58:52 2011

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

사용자명 입력: SYSTEM
암호 입력: [...암호입력...]
ERROR:
ORA-12154: TNS:지정된 접속 식별자를 분석할 수 없음

반면에, 테스트 계정인 "hr"로 로그인을 하면 잘 되고... ^^; 또다시 검색을 하던 끝에 아래의 글에서 겨우 힌트를 얻게 되었습니다.

SYS connect
; http://www.dbasupport.com/forums/archive/index.php/t-36782.html

결국 다음과 같이 실행해서 성공하게 되었고, (희한한 보안 구조군요... 비밀번호가 필요없다늬!)

C:\oraclexe\app\oracle\product\10.2.0\server\BIN>sqlplus sys/change_on_install@xe as sysdba

SQL*Plus: Release 10.2.0.1.0 - Production on 목 4월 7 01:06:41 2011

Copyright (c) 1982, 2005, Oracle.  All rights reserved.


다음에 접속됨:
Oracle Database 10g Express Edition Release 10.2.0.1.0 - Production

이어서, processes 파라미터 값을 한번 확인해 보고,

SQL> show parameter processes

NAME                                 TYPE
------------------------------------ ----------------------
VALUE
------------------------------
aq_tm_processes                      integer
0
db_writer_processes                  integer
1
gcs_server_processes                 integer
0
job_queue_processes                  integer
4
log_archive_max_processes            integer

NAME                                 TYPE
------------------------------------ ----------------------
VALUE
------------------------------
2
processes                            integer
40

이 값을 다음의 명령어로 수정해주었습니다.

alter system set processes=100 scope=spfile;

나중에 검색해서 알고 보니, XE의 경우에는 기본값을 늘려주라는 글이 있더군요.

Oracle XE Tuning
; https://rothmans.wordpress.com/2009/10/

이후, Oracle 서비스를 재시작하고,

net stop OracleXETNSListener
net stop OracleServiceXE

net start OracleServiceXE
net start OracleXETNSListener

이제는 연결 자체는 잘 되는데 전혀 다른 오류 현상이 발생했습니다.

select department_name from departments

[Oracle.DataAccess.Client.OracleException] ORA-12571: TNS:packet writer failure
   at Oracle.DataAccess.Client.OracleException.HandleErrorHelper(Int32 errCode, OracleConnection conn, IntPtr opsErrCtx, OpoSqlValCtx* pOpoSqlValCtx, Object src, String procedure, Boolean bCheck)
   at Oracle.DataAccess.Client.OracleException.HandleError(Int32 errCode, OracleConnection conn, String procedure, IntPtr opsErrCtx, OpoSqlValCtx* pOpoSqlValCtx, Object src, Boolean bCheck)
   at Oracle.DataAccess.Client.OracleCommand.ExecuteReader(Boolean requery, Boolean fillRequest, CommandBehavior behavior)
   at Oracle.DataAccess.Client.OracleCommand.ExecuteReader()
   at Jennifer40.WebSiteTest.odpnet20test.Page_Load(Object sender, EventArgs e) in d:\...[생략]...\odpnet20test.aspx.cs:line 277
   at System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e)
   at System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e)
   at System.Web.UI.Control.OnLoad(EventArgs e)
   at System.Web.UI.Control.LoadRecursive()
   at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)

재미있는 점은, ORA-12571 오류는 처음 서비스가 올라오는 과정에서만 잠시 발생하다가 테스트가 일정 시간 이상 진행되고 나서는 더 이상 발생하지 않는다는 것입니다. 일단, 테스트 시스템이었고, 더 이상 여기에 시간을 허비할 수 없었기 때문에 오늘은 여기까지만!!! (휴~~~ 오라클... 힘들군요.)




참고로, 알아둘 몇 가지.

1. 몇몇 파일의 위치 정리.

C:\oraclexe\app\oracle\product\10.2.0\server\NETWORK\log\listener.log
C:\oraclexe\app\oracle\product\10.2.0\server\NETWORK\ADMIN\listener.ora
C:\oraclexe\app\oracle\product\10.2.0\server\NETWORK\ADMIN\tnsnames.ora
C:\oraclexe\app\oracle\product\10.2.0\server\config\scripts\init.ora

2. OracleXETNSListener, OracleServiceXE 서비스가 시작되었다고 해서 곧바로 모든 리스너가 동작하지는 않는다는 점! 실제로, 서비스 재시작후 lsnrctl.exe 명령어를 이용해서 확인해 보면 다음과 같은 리스닝 목록이 출력됩니다.

C:\oraclexe\app\oracle\product\10.2.0\server\BIN>LSNRCTL.EXE status

LSNRCTL for 32-bit Windows: Version 10.2.0.1.0 - Production on 06-4월 -2011 22:02:42

Copyright (c) 1991, 2005, Oracle.  All rights reserved.

(DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC_FOR_XE)))에 연결되었습니다
리스너의 상태
------------------------
별칭                     LISTENER
버전                     TNSLSNR for 32-bit Windows: Version 10.2.0.1.0 - Production
시작 날짜                 06-4월 -2011 22:02:33
업타임                   0 일 0 시간. 0 분. 8 초
트레이스 수준            off
보안                     ON: Local OS Authentication
SNMP                     OFF기본 서비스           XE
리스너 매개변수 파일   C:\oraclexe\app\oracle\product\10.2.0\server\network\admin\listener.ora
리스너 로그 파일         C:\oraclexe\app\oracle\product\10.2.0\server\network\log\listener.log
끝점 요약 청취 중...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC_FOR_XEipc)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=testdb.testad.com)(PORT=1525)))
서비스 요약...
"CLRExtProc" 서비스는 1개의 인스턴스를 가집니다.
  "CLRExtProc" 인스턴스(UNKNOWN 상태)는 이 서비스에 대해 1 처리기를 가집니다.
"PLSExtProc" 서비스는 1개의 인스턴스를 가집니다.
  "PLSExtProc" 인스턴스(UNKNOWN 상태)는 이 서비스에 대해 1 처리기를 가집니다.
명령이 성공적으로 수행되었습니다

좀 더 기다린 다음에 확인을 해야, 다음과 같이 정상적으로 초기화되는 것을 확인할 수 있습니다.

C:\oraclexe\app\oracle\product\10.2.0\server\BIN>LSNRCTL.EXE status

LSNRCTL for 32-bit Windows: Version 10.2.0.1.0 - Production on 06-4월 -2011 21:59:11

Copyright (c) 1991, 2005, Oracle.  All rights reserved.

(DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC_FOR_XE)))에 연결되었습니다
리스너의 상태
------------------------
별칭                     LISTENER
버전                     TNSLSNR for 32-bit Windows: Version 10.2.0.1.0 - Production
시작 날짜                 06-4월 -2011 21:50:21
업타임                   0 일 0 시간. 8 분. 49 초
트레이스 수준            off
보안                     ON: Local OS Authentication
SNMP                     OFF기본 서비스           XE
리스너 매개변수 파일   C:\oraclexe\app\oracle\product\10.2.0\server\network\admin\listener.ora
리스너 로그 파일         C:\oraclexe\app\oracle\product\10.2.0\server\network\log\listener.log
끝점 요약 청취 중...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=\\.\pipe\EXTPROC_FOR_XEipc)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=testdb.testad.com)(PORT=1521)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=127.0.0.1)(PORT=8080))(Presentation=HTTP)(Session=RAW))
서비스 요약...
"CLRExtProc" 서비스는 1개의 인스턴스를 가집니다.
  "CLRExtProc" 인스턴스(UNKNOWN 상태)는 이 서비스에 대해 1 처리기를 가집니다.
"PLSExtProc" 서비스는 1개의 인스턴스를 가집니다.
  "PLSExtProc" 인스턴스(UNKNOWN 상태)는 이 서비스에 대해 1 처리기를 가집니다.
"XEXDB" 서비스는 1개의 인스턴스를 가집니다.
  "xe" 인스턴스(READY 상태)는 이 서비스에 대해 1 처리기를 가집니다.
"XE_XPT" 서비스는 1개의 인스턴스를 가집니다.
  "xe" 인스턴스(READY 상태)는 이 서비스에 대해 1 처리기를 가집니다.
"xe" 서비스는 1개의 인스턴스를 가집니다.
  "xe" 인스턴스(READY 상태)는 이 서비스에 대해 1 처리기를 가집니다.
명령이 성공적으로 수행되었습니다




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/10/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2011-04-08 10시59분
[lancers] 이렇게 어렵게 만들어야, 고객들이 유지보수 비용을 지불한다는 것을 Oracle은 알고 있는 듯.. ㅋㅋㅋ
[guest]
2011-04-08 11시33분
그러게요... ^^; 마이크로소프트는 너무 쉽게 만들어서 eco-system에 참여한 기업들을 어렵게 만들지만, 오라클은 너무 어렵게 만들어서 eco-system에 참여한 기업들을 돈 벌게 해주는 것 같습니다.
정성태

... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13119정성태8/18/20226756.NET Framework: 2044. .NET Core/5+ 프로젝트에서 참조 DLL이 보관된 공통 디렉터리를 지정하는 방법
13118정성태8/18/20225577.NET Framework: 2043. WPF Color의 기본 색 영역은 (sRGB가 아닌) scRGB [2]
13117정성태8/17/20227752.NET Framework: 2042. C# 11 - 파일 범위 내에서 유효한 타입 정의 (File-local types)파일 다운로드1
13116정성태8/4/20228217.NET Framework: 2041. C# - Socket.Close 시 Socket.Receive 메서드에서 예외가 발생하는 문제파일 다운로드1
13115정성태8/3/20228600.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교 [1]파일 다운로드1
13114정성태8/2/20228780.NET Framework: 2039. C# - Task와 비교해 본 ValueTask 사용법파일 다운로드1
13113정성태7/31/20228054.NET Framework: 2038. C# 11 - Span 타입에 대한 패턴 매칭 (Pattern matching on ReadOnlySpan<char>)
13112정성태7/30/20228439.NET Framework: 2037. C# 11 - 목록 패턴(List patterns) [1]파일 다운로드1
13111정성태7/29/20228183.NET Framework: 2036. C# 11 - IntPtr/UIntPtr과 nint/nuint의 통합파일 다운로드1
13110정성태7/27/20228258.NET Framework: 2035. C# 11 - 새로운 연산자 ">>>" (Unsigned Right Shift)파일 다운로드1
13109정성태7/27/20229698VS.NET IDE: 177. 비주얼 스튜디오 2022를 이용한 (소스 코드가 없는) 닷넷 모듈 디버깅 - "외부 원본(External Sources)" [1]
13108정성태7/26/20227618Linux: 53. container에 실행 중인 Golang 프로세스를 디버깅하는 방법 [1]
13107정성태7/25/20226771Linux: 52. Debian/Ubuntu 계열의 docker container에서 자주 설치하게 되는 명령어
13106정성태7/24/20226524오류 유형: 819. 닷넷 6 프로젝트의 "Conditional compilation symbols" 기본값 오류
13105정성태7/23/20227814.NET Framework: 2034. .NET Core/5+ 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 - 두 번째 이야기 [1]
13104정성태7/23/202210896Linux: 51. WSL - init에서 systemd로 전환하는 방법
13103정성태7/22/20227400오류 유형: 818. WSL - systemd-genie와 관련한 2가지(systemd-remount-fs.service, multipathd.socket) 에러
13102정성태7/19/20226810.NET Framework: 2033. .NET Core/5+에서는 구할 수 없는 HttpRuntime.AppDomainAppId
13101정성태7/15/202215752도서: 시작하세요! C# 10 프로그래밍
13100정성태7/15/20228227.NET Framework: 2032. C# 11 - shift 연산자 재정의에 대한 제약 완화 (Relaxing Shift Operator)
13099정성태7/14/20228129.NET Framework: 2031. C# 11 - 사용자 정의 checked 연산자파일 다운로드1
13098정성태7/13/20226298개발 환경 구성: 647. Azure - scale-out 상태의 App Service에서 특정 인스턴스에 요청을 보내는 방법 [1]
13097정성태7/12/20225693오류 유형: 817. Golang - binary.Read: invalid type int32
13096정성태7/8/20228634.NET Framework: 2030. C# 11 - UTF-8 문자열 리터럴
13095정성태7/7/20226692Windows: 208. AD 도메인에 참여하지 않은 컴퓨터에서 Kerberos 인증을 사용하는 방법
13094정성태7/6/20226434오류 유형: 816. Golang - "short write" 오류 원인
... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...