성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Working with Rust Libraries from C#...
[정성태] Detecting blocking calls using asyn...
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
[정성태] 저렇게 조각 코드 말고, 실제로 재현이 되는 예제 프로젝트를 압...
[정성태] Modules 창(Ctrl+Shift+U)을 띄워서, 해당 Op...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <br /> <div style='font-family: 맑은 고딕, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>.NET 응용 프로그램에서 64비트 Oracle Data Access Components 사용</div><br /> <br /> 이전의 글에서 ODAC 64비트 버전에 대해서는 링크만 걸고 지나갔었는데요.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > .NET 응용 프로그램에서 Oracle XE 사용 ; <a target='_tab' href='/2/0/821'>http://www.sysnet.pe.kr/2/0/821</a> 64-bit Oracle Data Access Components (ODAC) Downloads <ul style="display: inline;"> <li>64-bit <b style='COLOR: blue'>Oracle10g</b> Release 2 ODAC for Windows x64 - (<b style='COLOR: blue'>ODAC10203x64.zip</b>) ; <a target='_tab' href='http://www.oracle.com/technology/software/tech/windows/odpnet/64-bit/index.html'>http://www.oracle.com/technology/software/tech/windows/odpnet/64-bit/index.html</a> </li> <li><b style='COLOR: blue'>Oracle Database 11g</b> Release 1 Client (11.1.0.6.0) for Microsoft Windows (x64) - (<b style='COLOR: blue'>win64_11gR1_client.zip</b>) ; <a target='_tab' href='http://www.oracle.com/technology/software/products/database/oracle11g/111060_win64soft.html'>http://www.oracle.com/technology/software/products/database/oracle11g/111060_win64soft.html</a></li> </ul></pre> <br /> 정리하면, 10g 버전으로 나온 것이 "ODAC10203x64.zip"이고, 11g 버전으로 나온 것이 "win64_11gR1_client.zip"입니다. 이 2개의 설치 파일은 Windows Server <b style='COLOR: blue'>2003</b> x64에만 해당되고 Windows Server <b style='COLOR: blue'>2008</b> x64 용으로는 다음의 버전을 다운로드 받아야 합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > <b style='COLOR: blue'>Oracle Database 10g</b> Client Release 2 (10.2.0.4) - 10204_vista_w2k8_x64_production_client.zip (507,934,134 bytes) ; <a target='_tab' href='http://www.oracle.com/technology/software/products/database/oracle10g/htdocs/10204_winx64_vista_win2k8.html'>http://www.oracle.com/technology/software/products/database/oracle10g/htdocs/10204_winx64_vista_win2k8.html</a> <b style='COLOR: blue'>Oracle Database 11g</b> Release 1 Client (11.1.0.7.0) for Microsoft Windows Server 2008 x64 ; <a target='_tab' href='http://www.oracle.com/technology/software/products/database/oracle11g/111070_win64_2008soft.html '>http://www.oracle.com/technology/software/products/database/oracle11g/111070_win64_2008soft.html</a> </pre> <br /> 애석하게도 아직 위의 버전 모두 Windows Server 2008 R2에서는 설치 작업이 진행되지 않습니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> 3가지 설치 버전 중에서 이번에는 Windows Server 2003 x64 버전의 Oracle 10g R2 설치 파일인 "ODAC10203x64.zip"을 살펴보겠습니다. 간단히, ODAC10203x64.zip 파일을 압축 해제하고 install 폴더의 "setup.exe"를 실행하고 마치면 다음과 같은 식의 폴더가 생성되고 설치 작업이 완료됩니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > C:\oracle\product\10.2.0\client_1 </pre> <br /> [그림 1: ODAC x64 설치 후 생성된 폴더 구조]<br /> <img alt='deploy_odac_x64_1.png' src='/SysWebRes/bbs/deploy_odac_x64_1.png' /><br /> <br /> 이와 함께 다음과 같은 구조의 레지스트리가 생성됩니다.<br /> <br /> [그림 2: ODAC x64 설치 후 생성된 레지스트리 구조]<br /> <img alt='deploy_odac_x64_2.png' src='/SysWebRes/bbs/deploy_odac_x64_2.png' /><br /> <br /> 당연한 이야기이겠지만, 이렇게 설치하고 "<a target='_tab' href='/2/0/821'>.NET 응용 프로그램에서 Oracle XE 사용</a>"에서 살펴 본 예제 코드를 실행하면 아무런 부가작업 없이 실행이 됩니다. 물론, "ODAC10203x64.zip" 파일을 설치한 컴퓨터에서만 잘 됩니다. 그럼, 이것을 설치하지 않고도 파일 복사만으로 사용하는 방법이 있지 않을까요?<br /> <br /> 대충 살펴보니, 가능하다는 답이 나왔습 니다. 다행히 ODAC x64 설치과정에서 위에서 살펴 본 "파일 구조", "레지스트리 구조"를 빼고는 더 이상의 동작은 없었습니다. 즉, 레지스트리 구조만 잘 맞춰주면 파일 복사만으로 오라클을 사용하는 EXE 파일을 배포하는 것이 가능합니다.<br /> <br /> 방법은 다음과 같습니다.<br /> <br /> <ol> <li>오라클 설치 폴더인 "C:\oracle\product\10.2.0\client_1" 폴더를 EXE 하위 폴더에 복사 (물론, 별개의 폴더도 가능)<br /> [그림 3: EXE 파일과 같이 배포하는 ODAC x64 구성요소]<br /> <img alt='deploy_odac_x64_3.png' src='/SysWebRes/bbs/deploy_odac_x64_3.png' /><br /> - client_1 폴더의 크기가 310MB인데, 불필요하다고 생각되는 것은 삭제해도 무방합니다. 예를 들어, ".\client_1\jdk"와 같은 폴더</li><br /> <li>HKLM 레지스트리에 다음의 내용을 등록<br /> <SPAN style='BACKGROUND-COLOR: #ccffcc; FONT-STYLE: italic; MARGIN: 10px 0px 10px 10px; WIDTH: 800px; FONT-FAMILY: 맑은 고딕, Consolas, Verdana; COLOR: #005555'><br /> Windows Registry Editor Version 5.00<br /> <br /> [HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\KEY_ODACHome1]<br /> "ORACLE_HOME"="...EXE 폴더...\\client_1"<br /> <br /> [HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\ODP.NET]<br /> <br /> [HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\ODP.NET\2.102.3.2]<br /> "DllPath"="...EXE 폴더...\\10.2.0\\client_1\\bin"</span><br /><br /> [그림 4: 복사된 ODAC x64 구성요소가 동작하기 위한 최소 레지스트리 구성]<br /> <img alt='deploy_odac_x64_4.png' src='/SysWebRes/bbs/deploy_odac_x64_4.png' /><br /> </li><br /> </ol> <br /> 이렇게 구성하고 예제 응용 프로그램을 실행하면 정상적으로 동작하는데 단지 연결 문자열만 다음과 같이 바꿔주어야 합니다.<br /> <SPAN style='BACKGROUND-COLOR: #ccffcc; FONT-STYLE: italic; MARGIN: 10px 0px 10px 10px; WIDTH: 800px; FONT-FAMILY: 맑은 고딕, Consolas, Verdana; COLOR: #005555'><br /> string oradb = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=서버명 또는 IP주소)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=XE)));User Id=hr;Password=hr;";</span> <br /><br /> 또한, 비록 "ODAC10203x64.zip" 설치 버전이 Windows Server 2003 x64 운영체제에만 설치되지만, Windows Server 2008 x64와 Windows Server 2008 R2에서도 위와 같이 "복사된 버전"으로 실행하면 정상적으로 EXE 응용 프로그램이 동작합니다. 단지, UAC 제한으로 인해 "관리자 권한"으로 실행해야 하는 단점이 있을 뿐입니다.<br /> <br /> 자... 이것으로 그럼, 일단 x64 버전에서도 아쉬운 데로 레지스트리 등록을 제외하고는 Xcopy 형식의 배포가 가능하게 되었군요.<br /> <br /> 마지막으로, 주의 사항을 하나 추가하면 "Oracle.DataAccess.dll" 파일이 "Any CPU"로 빌드된 것이 아니고 x86, x64 개별버전으로 빌드되어 있기 때문에 하나의 프로젝트에서 x86/x64에서 동시 사용되는 버전을 만드는 것은 힘들다는 정도!<br /> <br /><br /><hr /><span style='color: Maroon'>[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
6235
(왼쪽의 숫자를 입력해야 합니다.)