Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 2개 있습니다.)
(시리즈 글이 6개 있습니다.)
개발 환경 구성: 63. ODP.NET 설치 없이 .NET 클라이언트 프로그램 배포하는 방법
; https://www.sysnet.pe.kr/2/0/822

개발 환경 구성: 64. ODP.NET 설치 작업 없이 ASP.NET 응용 프로그램 배포
; https://www.sysnet.pe.kr/2/0/823

개발 환경 구성: 65. .NET 응용 프로그램에서 64비트 Oracle Data Access Components 사용
; https://www.sysnet.pe.kr/2/0/825

개발 환경 구성: 66. .NET 응용 프로그램에서 64비트 Oracle Data Access Components 사용 (2)
; https://www.sysnet.pe.kr/2/0/827

개발 환경 구성: 67. 환경 변수를 이용한 다중 ODAC 버전 테스트
; https://www.sysnet.pe.kr/2/0/828

개발 환경 구성: 68. ODP.NET + OraMTS 사용
; https://www.sysnet.pe.kr/2/0/829




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 설치 없이 실행되는 응용 프로그램 배포]
how_to_deploy_odpnet_1.png




그런데, 의존성 문제가 하나 더 있습니다. 테스트하면서 알게 되었는데, 특정 컴퓨터에서는 다음과 같이 예외가 발생하였습니다.


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개로 나눴습니다.






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

[연관 글]






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

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

비밀번호

댓글 작성자
 



2010-01-04 11시34분
Installing Oracle Data Provider for .NET
; http://download.oracle.com/docs/html/E10927_01/InstallODP.htm

위의 글에 따르면 unmanaged DLL이 위치한 폴더를 찾는 기준이 다음과 같다고 합니다.

1.Directory of the application or executable.

2.DllPath setting specified by application config or web.config.

3.DllPath setting specified by machine.config.

4.DllPath setting specified by the Windows Registry.

HKEY_LOCAL_ MACHINE\Software\Oracle\ODP.NET\version\DllPath

5.Directories specified by the Windows PATH environment variable.
kevin25
2010-10-07 10시47분
[전광식] 주인장님 잘보고 샘플 잘 실행 보았습니다.

그런데 서버가 10g를 쓰고 있어서 11g로 테스트를 하니
C:\testClient>test

처리되지 않은 예외: System.TypeInitializationException: 'Oracle.DataAccess.Clien
t.OracleConnection'의 형식 이니셜라이저에서 예외를 Throw했습니다. ---> Oracle.Da
taAccess.Client.OracleException 제공자가 Oracle 클라이언트 버전과 호환되지 않습
니다. 위치: Oracle.DataAccess.Client.OracleInit.Initialize()
   위치: Oracle.DataAccess.Client.OracleConnection..cctor()
   --- 내부 예외 스택 추적의 끝 ---
   위치: Oracle.DataAccess.Client.OracleConnection..ctor(String connectionString
)
   위치: ConsoleApplication2.Program.Main(String[] args)

에러가 나네요
10g가 설치되어있는 서버에서는 잘 실행됩니다~


오라클 10g xcopy 버전도 오라클에서 제공하지 않는것같고
10g로도 배포가 가능한지 궁금합니다
[guest]
2010-10-08 10시04분
음... ^^ 그런 부분의 호환 문제는 저도 뭐라 드릴 말씀이 없군요. 저도 이 부분은 직접 환경 구성해서 테스트 해봐야 할텐데, 그럴만한 시간적인 여유가 없군요. ^^ 언젠가 다시 오라클 환경 구성을 해야 할 때가 되면 시도해보겠습니다. ^^
kevin25
2010-10-12 10시50분
[전광식] 네 감사합니다^^~!!
[guest]
2010-10-12 11시46분
[전광식] 위의 에러메세지는 기존 테스트PC에 11g클라이언트가 설치 되어있어 나온에러였습니다~!^^;
[guest]
2014-07-03 08시50분
정말 필요한 정보였는데 정확하게 들어 맞네요. 11g 에서 같은 방법으로 처리 하였습니다. 감사합니다. ^^
sequel2

... 151  152  [153]  154  155  156  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1227정성태2/3/201229257.NET Framework: 299. 해당 어셈블리가 Debug 빌드인지, Release 빌드인지 알아내는 방법파일 다운로드1
1226정성태1/28/201270170.NET Framework: 298. 홀 펀칭(Hole Punching)을 이용한 Private IP 간 통신 - C# [15]파일 다운로드3
1225정성태1/24/201225770.NET Framework: 297. 특정 EXE 파일의 실행을 Internet Explorer처럼 "Protected Mode"로 실행하는 방법 [1]파일 다운로드1
1224정성태1/21/201237283개발 환경 구성: 139. 아마존 EC2에 새로 추가된 "1년 무료 Windows 서버 인스턴스"가 있다는데, 직접 만들어 볼까요? ^^ [11]
1223정성태1/20/201227298.NET Framework: 296. 괜찮은 문자열 해시함수? - 두 번째 이야기 [1]파일 다운로드1
1222정성태1/18/201235022.NET Framework: 295. 괜찮은 문자열 해시 함수? [4]파일 다운로드1
1221정성태1/17/201224006오류 유형: 147. System.Runtime.InteropServices.COMException (0x80005000)
1220정성태1/15/201224161.NET Framework: 294. Master web.config 파일을 수정하려면?파일 다운로드1
1219정성태1/15/201226567.NET Framework: 293. Microsoft PowerPoint 슬라이드를 HTML 파일로 ".files" 폴더 없이 저장하는 방법 (C# 코드)파일 다운로드1
1218정성태1/15/201239089.NET Framework: 292. RSACryptoServiceProvider의 공개키와 개인키 구분 [1]파일 다운로드2
1217정성태1/14/201241177.NET Framework: 291. .NET에서 WAV, MP3 파일 재생하는 방법 [1]파일 다운로드1
1216정성태1/14/201229890오류 유형: 146. Microsoft Visual C++ 재배포 패키지 - 설치 로그 남기는 방법 [1]
1215정성태1/9/201227443제니퍼 .NET: 20. 제니퍼 닷넷 적용 사례 (3) - '닷넷'이 문제일까? '닷넷 개발자'가 문제일까? [6]
1214정성태1/3/201224295제니퍼 .NET: 19. 제니퍼 닷넷 설치/제거 방법 - IIS
1213정성태12/31/201124222.NET Framework: 290. WCF - 접속된 클라이언트의 IP 주소 알아내는 방법 - 두 번째 이야기
1212정성태12/31/201124334오류 유형: 145. The trust relationship between this workstation and the primary domain failed.
1211정성태12/31/201129131.NET Framework: 289. WindowsFormsHost를 사용하는 XBAP 응용 프로그램파일 다운로드1
1210정성태12/30/201148105.NET Framework: 288. FFmpeg.exe를 이용한 C# 동영상 인코더 예제 [9]파일 다운로드1
1209정성태12/29/201122748개발 환경 구성: 138. BizTalk 2006 설치 방법
1208정성태12/28/201145717.NET Framework: 287. Excel Sheet를 WinForm에서 사용하는 방법 [8]파일 다운로드2
1207정성태12/26/201124995.NET Framework: 286. x86/x64로 구분된 코드를 포함하는 경우, 다중으로 어셈블리를 만들어야 할까요?파일 다운로드1
1206정성태12/25/201126009.NET Framework: 285. Shader 강좌와 함께 배워보는 XNA Framework (3) - 텍스처 매핑 예제파일 다운로드1
1205정성태12/25/201131701.NET Framework: 284. Thread 개체의 Interrupt와 Abort의 차이점파일 다운로드1
1204정성태12/22/201125201.NET Framework: 283. MEF를 ASP.NET에 성능 손실 없이 적용하려면? [7]
1203정성태12/21/201125570제니퍼 .NET: 18. MEF가 적용된 ASP.NET 웹 사이트를 제니퍼 닷넷으로 모니터링 해본 결과! [6]
1202정성태12/21/201125981오류 유형: 144. The database '...' cannot be opened because it is version 661.
... 151  152  [153]  154  155  156  157  158  159  160  161  162  163  164  165  ...