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

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

오라클 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]

1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
5566민성10/26/20215270Linq에 관해서 [1]
5565pass...10/25/20216541wpf에서 Cefsharp를 AnyCPU로 작업 했는데 실행이 되지 않습니다. [4]
5564초보10/21/20214797오버라이드 관련 질문드립니다 [2]
5562서지훈10/20/20214792win32 api 문의 드립니다. (EnableMenuItem) [5]
5561Edun10/15/20215246도와주세요!! 팝업 띄우는 더블클릭 이벤트!! 부탁드립니다 ㅠㅠ [4]파일 다운로드1
5560Edun10/13/20215417C#초보자 개념이해 도와주세요!! [4]
5559최가운10/5/20215725C# debugging 중에 Thread Pool Worker들이 사라지는데요 [3]
5558옥코드9/29/20215964안녕하세요! EntityFramework Linq 질문 드리겠습니다. [4]
5557임기성9/16/20216523웹 사이트(IIS)가 오류로 인하여 빈번하게 죽는 이슈 문의 [1]
5556hjlee9/13/20215318visual studio 설치 없이 csi.exe (C# interactive) tool을 설치할 수 있을까요? [2]
5555이성열 donator9/2/20215131C# 런타임(Reflection)에서 소스코드에 입력한 함수설명(Summary)을 가져올 수 있을까요? [3]
5554농상9/2/20215848enum 원소값이 중복인 경우 출력 [4]
5553shdt...8/31/20214803제너릭을 new로 할당했는데 null인 경우가 존재하나요? [1]
5552hjsh...8/30/20215069C# 폼 - 마우스가 다른 버튼 위를 움직일 때도 폼의 페인트핸들러가 호출되는 것이 맞나요? [2]
5551하나다라마8/27/20215188뽀모도로 타이머 개선사항 [1]
5550하영8/27/20216273SqlDataReader 관련 질문입니다. [8]
5549책 감사...8/23/20217707C# 9.0 책 오타 [1]
5548Dev8/23/20216016String의 IndexOfAny 함수 질문 [3]
5547민성8/20/20215425WPF Radio 버튼을 GroupName으로 읽어와서 비교하기 [1]
5546Deve...8/19/20216286C++ C# API 연동 관련 [1]
5545영귤8/18/20215219C# 14.3장 예제에서 반환 값의 값 복사 부하가 어디서 발생하는 것인가요? [4]
5544이상호8/18/20215547C# Graphics 객체 저장 가능 여부 [2]
5543정형지8/18/20215297c# outofmemoryexception [3]
5542영귤8/11/20218026C#9.0 886쪽 오류 발생 안 해요 [2]
5541서지훈8/11/20218766C# 응용프로그램(Winform)의 비정상 종료(Exit Code) [2]
5540산들마을...8/11/20216343C# 많은 Control(Label 300개) Update 관련 문의 [2]파일 다운로드1
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...