Microsoft MVP성태의 닷넷 이야기
오라클 DB서버 접속관련 문의 드립니다.(Load Balancing, HA Events) [링크 복사], [링크+제목 복사],
조회: 3380
글쓴 사람
감사합니다.
홈페이지
첨부 파일
 

안녕하세요?
항상 도움주셔서 감사합니다.

오라클 DB서버 접속을 하는데 다음 두가지 기능을 활용하고 싶은데 기능 동작이 되지 않아서
혹시 해당 문제에 경험이 있으시면 조언을 얻고자 문의드립니다.

현재 오라클 DB서버는 아래와 같은 라이브러리를 이용해서 접속하고 있습니다.
https://www.sysnet.pe.kr/2/0/10928


활용하고 싶은 기능은 아래 두가지입니다.
Load Balancing : (ADDRESS=(PROTOCOL=TCP)(HOST=IP1)(PORT=1521))(ADDRESS=(PROTOCOL=TCP)(HOST=IP2)(PORT=1521)) 로 설정된 여러 DB서버중에서
                 랜덤으로 접속해서 오라클 DB서버 로드를 분산하는 기능

 
HA Events : (ADDRESS=(PROTOCOL=TCP)(HOST=IP1)(PORT=1521))(ADDRESS=(PROTOCOL=TCP)(HOST=IP2)(PORT=1521)) 로 설정된 여러 DB서버중에서
접속하려는 서버에 실패했을 경우 다른 DB서버로 접속하기 위한 기능


위의 두가지 기능을 활용하기 위해서 아래사이트에서 설명된 설정값인 Load Balancing와 HA Events를 모두 true로 해서 Connection String 옵션값에 설정하고 접속테스트를 해보았습니다.
https://docs.oracle.com/database/121/ODPNT/featConnecting.htm#ODPNT163

그런데 아무리 테스트를 해봐도 위의 두가지가 제대로 동작하지 않는것 같습니다.


Load Balancing 기능 같은 경우는 항상 첫번째에 기술된 서버에만 접속을 하고
HA Events 기능 같은 경우는 Connection Timeout 예외가 발생을 하네요.


혹시 ODP.NET(Oracle.ManagedDataAccess.dll)를 이용해서 오라클 DB서버에 접속할 때 Load Balancing과 HA Events 기능을
활용하기 위한 방법이 무엇인지 아시는분 알려주시면 감사하겠습니다.

추가적으로 해당 DB서버에 접속할 때 ODP.NET방식을 사용하지 않고 ODAC 오라클 클라이언트 프로그램을 설치해서 Oledb로 접속을 하면 Load Balancing과 HA Events기능이 정상적으로 동작하는 것으로 봐서
오라클 DB서버 설정 문제는 아닌것으로 생각됩니다.

감사합니다.








[최초 등록일: ]
[최종 수정일: 2/28/2023]


비밀번호

댓글 작성자
 



2023-03-01 12시48분
저도 관련해서 경험이 없어 모르겠습니다. (실습 환경도 없고. ^^)

그런데, 문서를 보면,

https://docs.oracle.com/en/database/oracle/oracle-database/21/odpnt/InstallManagedConfig.html

다음과 같은 문구가 있습니다.

Though managed ODP.NET does not support TNS descriptor based load balancing, it does support failover through both an ADDRESS_LIST and DESCRIPTION_LIST.

Note that you need not specify either the LOAD_BALANCE or the FAILOVER directive, because only failover is supported. The directives are ignored.

문서에 날짜가 없어서... 현재 버전은 지원하고 있는지도 모르겠지만... 관련해서 oracle 측에 문의를 넣어보는 것이 좋을 듯합니다.
정성태
2023-03-02 11시23분
[감사합니다.] 네 답변감사드립니다.
[guest]

... 16  17  [18]  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5485이재원4/17/20216450교재 315페이지 내용 질문 [3]
5484Syong4/16/202110031윈폼 기반의 응용프로그램 dll 참조와 32,64bit 빌드 관련 문의 [4]
5483한예지 donator4/15/20215543익명 형식과 var 관계 질문 있습니다. [2]
5482질문4/13/20217332WPF를 위한 MVVM toolkit 선택과 관련한 문의드립니다. [4]
5480한예지 donator4/5/20217652GetHashCode 질문있습니다! [2]
5479한예지 donator4/4/20216739Equals를 닷넷에서 어떻게 구현했는지 보고 싶을 떄는 어떻게 해야 될까요? [2]
5478갑자기C#3/23/20219235C# Winform에서 TextBox없이 입력 받을 수 있나요? [7]
5477달팽이3/18/20216175c# 도형을 그린후 편집하는 방법이 궁금합니다. [2]파일 다운로드1
5475dimo...3/2/20217147POH가 .NET 5에 추가된 것으로 알고 있습니다. POH가 유용한 경우는 어떤 경우가 있을까요? [1]
5474Syong2/26/20216664사용자 지정 컨트롤 생성시 Invalidate, Update, Refresh의 차이점 [2]
5473한예지 donator2/25/20216553디자인 타임이 뭔지 궁금합니다!! [5]
5472dimo...2/24/20217374등록하지 않고 ocx를 사용하는 `키움`관련 포스팅을 따라가다 질문드립니다. [9]
5471남산2/21/20216020MarshalDirectiveException 에 대한 질문입니다. [1]
5470한예지 donator2/7/20215942yield 질문있습니다!! [2]
5469유호성2/6/20215505Parallel + Task.Run 동시 실행 환경에서 간헐적으로 Task.Run()에서 null이 리턴됩니다. [3]파일 다운로드1
5467hero...2/4/20215852실행 환경에 따른 Thread.Sleep 딜레이 차이 질문 [8]
5466pr1/29/20215739c# winform load시 작업표시줄에 뜨지 않는 현상을 겪으신적이 있으신가요? [4]파일 다운로드1
5465영귤1/28/20216129두 번째 await 부터는 스레드 개수만 늘어나는 것이 아닌가요 [1]
5464민우1/26/20216386C# 빌드시 코드 치환되는걸 확인하는 방법 문의 [2]
5463한예지 donator1/24/20217160Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [2]
5462C#초보1/22/20217475사용자 정의 메시지 전달이 가능한가요? [2]
5461한예지 donator1/22/20216881AsEnumerable() 메서드 질문 있습니다! [2]
5459한예지 donator1/21/20216206typeof와 GetType의 차이점 질문있습니다. [2]
5458진우1/20/20217108C# DataTable 에 SQL 쿼리문을 실행하는 방법 문의 (LINQ 사용하지 않고) [6]
5456성민1/17/202175289.0 출간 계획이 있으신가요? [2]
5455한예지 donator1/16/20216584교재 194페이지 콜백메서드 질문 있습니다! [5]
... 16  17  [18]  19  20  21  22  23  24  25  26  27  28  29  30  ...