ODP.NET 설치 없이 .NET 클라이언트 프로그램 배포하는 방법
지난 이야기에서, 닷넷 응용 프로그램에서 Oracle에 접속하는 방법을 알아봤습니다.
.NET 응용 프로그램에서 Oracle XE 사용
; https://www.sysnet.pe.kr/2/0/821
그런데, 글을 읽어보신 분들은 실망하시겠지만 ODP.NET을 Xcopy 버전으로 다운로드 받았는데도 불구하고 install.bat 파일을 실행해줘야 했고 PATH 환경변수에 등록하는 작업을 했었습니다.
물론 ^^ 그런 과정없이 바로 클라이언트 프로그램을 배포하는 것도 가능합니다. 이에 대해서는 다음의 글에 나와 있습니다.
Using the new ODP.Net to access Oracle from C# with simple deployment
; http://splinter.com.au/blog/?p=156
위의 글은 약간 오래된 것 같은데, "Oracle 11g ODAC 11.1.0.7.20 with Xcopy Deployment" 버전으로 정리해 보면 다음의 DLL들이 EXE 파일과 같은 폴더에 복사되어 있으면 정상 동작합니다.
- oci.dll (E:\oracle2\odpnet20)
- ociw32.dll (E:\oracle2\odpnet20)
- oraociei11.dll (E:\oracle2\odpnet20)
- OraOps11w.dll (E:\oracle2\odpnet20\bin)
- Oracle.DataAccess.dll (E:\oracle2\odpnet20\odp.net\bin\2.x)
약간 황당한 면이 있다면, "oraociei11.dll" 파일의 크기가 104MB나 된다는! ^^;
그래서, 만약 ODP.NET을 사용한 응용 프로그램을 배포한다면 다음과 같이 파일들이 구성되어 있어야 클라이언트 측에 ODP.NET을 설치하는 작업없이도 응용 프로그램이 정상적으로 실행됩니다.
[그림 1: ODP.NET 설치 없이 실행되는 응용 프로그램 배포]
그런데, 의존성 문제가 하나 더 있습니다. 테스트하면서 알게 되었는데, 특정 컴퓨터에서는 다음과 같이 예외가 발생하였습니다.
C:\...>ConsoleApplication2.exe
Unhandled Exception: System.TypeInitializationException: The type initializer for 'Oracle.DataAccess.Client.OracleConnection' threw an exception. ---> Oracle.DataAccess.Client.OracleException The provider is not compatible with the version of Oracle client
at Oracle.DataAccess.Client.OracleInit.Initialize()
at Oracle.DataAccess.Client.OracleConnection..cctor()
--- End of inner exception stack trace ---
at Oracle.DataAccess.Client.OracleConnection..ctor(String connectionString)
at ConsoleApplication2.Program.Main(String[] args)
혹시나 싶어, Depends.exe로 살펴보니 oci.dll, ociw32.dll, oraociei11.dll들이 모두 msvcr71.dll에 종속성을 가지고 있었습니다. 즉, 예외가 발생한 컴퓨터에서는 msvcr71.dll이 없었기 때문에 그와 같은 오류가 발생했다는 것이고.
정리해 보면, ODP.NET을 설치 과정없이 "대부분의" 클라이언트 측 컴퓨터에서 곧바로 실행하기를 원한다면 EXE 파일이 놓인 곳에 다음과 같이 6가지의 DLL들이 존재해야 합니다.
- Oracle.DataAccess.dll
- OraOps11w.dll
- oci.dll
- ociw32.dll
- oraociei11.dll
- msvcr71.dll
첨부한 프로젝트에는 "
.NET 응용 프로그램에서 Oracle XE 사용" 글에서 사용된 예제 코드를 포함하고 있습니다. 또한 위와 같은 설정이 반영되었으므로 Oracle XE가 설치된 원격(또는 로컬)PC가 구성된 환경이라면 곧바로 테스트 해볼 수가 있습니다. "...[압축해제폴더]...\ConsoleApplication2\bin\Debug" 폴더의 "ConsoleApplication2.exe.config" 파일을 열면 다음과 같이 구성되어 있는데,
<?xml version="1.0"?>
<configuration>
<configSections>
... [생략] ...
</configSections>
<startup>
<supportedRuntime version="v2.0.50727"/></startup>
<applicationSettings>
<ConsoleApplication2.Properties.Settings>
<setting name="ConnectionString" serializeAs="String">
<value>user id=hr;password=hr; data source=svrname</value>
</setting>
</ConsoleApplication2.Properties.Settings>
</applicationSettings>
</configuration>
연결 문자열 부분만 적절하게 자신의 환경에 맞게 설정해 주고 "ConsoleApplication2.exe" 파일을 실행해 주면 정상적으로 화면에 "Administration"이라는 문자열이 출력될 것입니다.
참고로, "oraociei11.dll" 파일이 100MB가 넘기 때문에 첨부 파일을 2개로 나눴습니다.
[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]