.NET 응용 프로그램에서 64비트 Oracle Data Access Components 사용
이전의 글에서 ODAC 64비트 버전에 대해서는 링크만 걸고 지나갔었는데요.
.NET 응용 프로그램에서 Oracle XE 사용
; https://www.sysnet.pe.kr/2/0/821
64-bit Oracle Data Access Components (ODAC) Downloads
정리하면, 10g 버전으로 나온 것이 "ODAC10203x64.zip"이고, 11g 버전으로 나온 것이 "win64_11gR1_client.zip"입니다. 이 2개의 설치 파일은 Windows Server
2003 x64에만 해당되고 Windows Server
2008 x64 용으로는 다음의 버전을 다운로드 받아야 합니다.
Oracle Database 10g Client Release 2 (10.2.0.4) - 10204_vista_w2k8_x64_production_client.zip (507,934,134 bytes)
; http://www.oracle.com/technology/software/products/database/oracle10g/htdocs/10204_winx64_vista_win2k8.html
Oracle Database 11g Release 1 Client (11.1.0.7.0) for Microsoft Windows Server 2008 x64
; http://www.oracle.com/technology/software/products/database/oracle11g/111070_win64_2008soft.html
애석하게도 아직 위의 버전 모두 Windows Server 2008 R2에서는 설치 작업이 진행되지 않습니다.
3가지 설치 버전 중에서 이번에는 Windows Server 2003 x64 버전의 Oracle 10g R2 설치 파일인 "ODAC10203x64.zip"을 살펴보겠습니다. 간단히, ODAC10203x64.zip 파일을 압축 해제하고 install 폴더의 "setup.exe"를 실행하고 마치면 다음과 같은 식의 폴더가 생성되고 설치 작업이 완료됩니다.
C:\oracle\product\10.2.0\client_1
[그림 1: ODAC x64 설치 후 생성된 폴더 구조]
이와 함께 다음과 같은 구조의 레지스트리가 생성됩니다.
[그림 2: ODAC x64 설치 후 생성된 레지스트리 구조]
당연한 이야기이겠지만, 이렇게 설치하고 "
.NET 응용 프로그램에서 Oracle XE 사용"에서 살펴 본 예제 코드를 실행하면 아무런 부가작업 없이 실행이 됩니다. 물론, "ODAC10203x64.zip" 파일을 설치한 컴퓨터에서만 잘 됩니다. 그럼, 이것을 설치하지 않고도 파일 복사만으로 사용하는 방법이 있지 않을까요?
대충 살펴보니, 가능하다는 답이 나왔습 니다. 다행히 ODAC x64 설치과정에서 위에서 살펴 본 "파일 구조", "레지스트리 구조"를 빼고는 더 이상의 동작은 없었습니다. 즉, 레지스트리 구조만 잘 맞춰주면 파일 복사만으로 오라클을 사용하는 EXE 파일을 배포하는 것이 가능합니다.
방법은 다음과 같습니다.
- 오라클 설치 폴더인 "C:\oracle\product\10.2.0\client_1" 폴더를 EXE 하위 폴더에 복사 (물론, 별개의 폴더도 가능)
[그림 3: EXE 파일과 같이 배포하는 ODAC x64 구성요소]

- client_1 폴더의 크기가 310MB인데, 불필요하다고 생각되는 것은 삭제해도 무방합니다. 예를 들어, ".\client_1\jdk"와 같은 폴더
- HKLM 레지스트리에 다음의 내용을 등록
Windows Registry Editor Version 5.00
[HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\KEY_ODACHome1]
"ORACLE_HOME"="...EXE 폴더...\\client_1"
[HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\ODP.NET]
[HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\ODP.NET\2.102.3.2]
"DllPath"="...EXE 폴더...\\10.2.0\\client_1\\bin"
[그림 4: 복사된 ODAC x64 구성요소가 동작하기 위한 최소 레지스트리 구성]

이렇게 구성하고 예제 응용 프로그램을 실행하면 정상적으로 동작하는데 단지 연결 문자열만 다음과 같이 바꿔주어야 합니다.
string oradb = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=서버명 또는 IP주소)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=XE)));User Id=hr;Password=hr;";
또한, 비록 "ODAC10203x64.zip" 설치 버전이 Windows Server 2003 x64 운영체제에만 설치되지만, Windows Server 2008 x64와 Windows Server 2008 R2에서도 위와 같이 "복사된 버전"으로 실행하면 정상적으로 EXE 응용 프로그램이 동작합니다. 단지, UAC 제한으로 인해 "관리자 권한"으로 실행해야 하는 단점이 있을 뿐입니다.
자... 이것으로 그럼, 일단 x64 버전에서도 아쉬운 데로 레지스트리 등록을 제외하고는 Xcopy 형식의 배포가 가능하게 되었군요.
마지막으로, 주의 사항을 하나 추가하면 "Oracle.DataAccess.dll" 파일이 "Any CPU"로 빌드된 것이 아니고 x86, x64 개별버전으로 빌드되어 있기 때문에 하나의 프로젝트에서 x86/x64에서 동시 사용되는 버전을 만드는 것은 힘들다는 정도!
[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]