Microsoft MVP성태의 닷넷 이야기
Java: 11. 웹 로직에서 MS-SQL 서버 연결 [링크 복사], [링크+제목 복사],
조회: 35204
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

웹 로직에서 MS-SQL 서버 연결


웹 로직에서 SQL 서버를 연결하려면 2가지 방법이 있는데, 하나는 BEA에서 제공되는 JDBC Driver를 사용하는 것이고, 다른 하나는 Microsoft에서 제공되는 드라이버를 사용하는 것입니다. 우선, 설정이 BEA 것이 쉬우니 그것 먼저 알아보겠습니다.

웹 로직 관리 콘솔에서 "Domain Structure" / " Services" / "JDBC" / "Data Sources" 노드를 선택하고 새로운 "Data Source"를 추가하기 위해 "New" 버튼을 눌러 다음과 같은 화면이 나오면 "Database Type"은 "MS SQL Server"로 맞추고, "Database Driver"는 "BEA's MS SQL Server Driver (Type 4) Versions: 7.0, 2000, 2005" 항목을 선택합니다.

weblogic_sql_connection_error_1.png

그다음 Next 버튼을 눌러 "Create a New JDBC Data Soruce" 패널이 나오면, 기본값으로 두고 "Next" 버튼을 누릅니다.

weblogic_sql_connection_error_2.png

이제부터 본격적인 "MS SQL Database Server"에 대한 연결 문자열 설정에 들어가는데요. 기본적으로 "Database User Name"에 "weblogic"이 들어가 있는데, MS SQL 서버에 등록된 보안 계정으로 입력해 주시면 됩니다. (솔직히 이 화면이 존재하는 이유를 모르겠습니다. 왜냐고요? ^^)

weblogic_sql_connection_error_3.png

위의 화면에서 "Next" 버튼을 누르면 아래와 같은 화면이 나오는데, 웬일인지 "Database User Name"이 본래대로 "weblogic"으로 돌아가버렸습니다. 설령 다시 MS SQL 서버의 보안 계정을 입력해도 이 상태에서 "Test Configuration" 버튼을 눌러서 연결 확인을 해보면 정상적으로 연결되지 않습니다. 왜냐하면, 아래의 화면에 나오는 패스워드도 이전 화면에서 입력해 두었던 패스워드가 아니기 때문입니다.

weblogic_sql_connection_error_4.png

자, 그럼 다시 입력하고 "Test Configuration"을 버튼을 눌러서 연결이 정상적으로 되는지 확인하면 다음과 같은 화면으로 넘어가게 됩니다. 보시는 것처럼, (암호를 포함해서) 사용자 계정 정보가 다시 초기화되었습니다. 상단의 "Connection test succeeded" 메시지를 믿고 그냥 무심결에 "Next" / "Finish" 버튼을 누르면 안 됩니다. 반드시 계정 정보를 다시 입력하고 그다음으로 넘어가야 합니다.

weblogic_sql_connection_error_5.png

이전에 입력한 계정 정보가 올바른지의 여부에 상관없이 아래의 화면이 나오게 되고, 이렇게 설정이 완료된 JDBC Data Soruce를 이용할 웹 애플리케이션을 선택합니다.

weblogic_sql_connection_error_6.png

이제 Finish 버튼을 누르면 "Data Source" 항목은 생성되고, 최종적으로 "Activate Changes" 버튼을 누르는 것으로 시스템에 반영시킬 수 있습니다.

이야기만으로도, ^^; 꽤나 불친절한 화면 구성임에는 틀림없습니다. (아마도 최신 버전의 WebLogic에는 개선이 되었을 것으로 생각됩니다.)




다음으로, "BEA's MS SQL Server Driver (Type 4) 7.0, 2000, 2005)"가 아닌, 마이크로소프트 측에서 제공해주는 JDBC Driver를 사용하는 방법을 알아볼텐데요. 위에서 이미 단계를 모두 보여드렸기 때문에 세세한 화면 캡쳐는 생략하고 단지 첫 화면에서만 "Database Driver"를 "Microsoft's MS SQL Server Driver (Type 4) Versions:2005"로 변경해 주면 됩니다. 이후의 단계에서는 계정 정보를 새롭게 매번 입력해 주어야 하는 것까지도 모두 똑같으니 그대로 진행하시면 됩니다.

그런데, 문제는 BEA 측에서 "Driver 선택 항목"만 제공해주는 것일뿐 JDBC Driver를 구현하고 있는 jar 파일 자체는 별도로 다운로드 받아서 넣어주도록 하는 데에 있습니다. 만약, 이런 부가적인 설정 없이 "JDBC Driver"를 생성할 때 "Test Configuration" 버튼을 눌러 확인하면 다음과 같이 "java.lang.ClassNotFoundException" 예외가 발생합니다.

<2011. 9. 30 오후 9시 28분 56초 KST> <Error> <Console> 
<BEA-240003> <Console encountered the following error java.lang.ClassNotFoundException: 
    Cannot load driver: com.microsoft.sqlserver.jdbc.SQLServerDriver
        at com.bea.console.utils.jdbc.JDBCUtils.testConnection(JDBCUtils.java:500)
        at com.bea.console.actions.jdbc.datasources.createjdbcdatasource.CreateJDBCDataSource.testConnectionConfiguration(CreateJDBCDataSource.java:369)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)

검색해 보니 다음의 글이 나오는데,

SQL 2005 and Weblogic : JDBC configuration error
; https://forums.oracle.com/forums/thread.jspa?threadID=723626

"SQL Server 2005 JAR file" 파일이라면 예전에 실습하던 "sqljdbc4.jar"일까요?

자바에서 "Microsoft SQL Server JDBC Driver" 사용하는 방법
; https://www.sysnet.pe.kr/2/0/1116

일단, sqljdbc4.jar 파일을 "D:\bea\wlserver_10.0\server\lib" 폴더에 복사하고 "D:\bea\user_projects\domains\testDomain\bin\setDomainEnv.cmd" 파일내의 CLASSPATH를 다음과 같이 변경해 주었습니다.

@REM SET THE CLASSPATH

set CLASSPATH=%PRE_CLASSPATH%;%WEBLOGIC_CLASSPATH%;%POST_CLASSPATH%;%WLP_POST_CLASSPATH%;D:\bea\wlserver_10.0\server\lib\sqljdbc4.jar

이렇게 변경하니 효과가 있는 것 같습니다. 그런데, 이번엔 오류가 바뀌었군요. ^^;

Error opening /com/bea/console/actions/jdbc/datasources/createjdbcdatasource/CreateJDBCDataSource.jpf.
 The source of this error is com.bea.portlet.adapter.scopedcontent.ActionLookupFailedException: 
 java.lang.UnsupportedClassVersionError: Bad version number in .class file 
 at com.bea.portlet.adapter.scopedcontent.ScopedContentCommonSupport.executeAction(ScopedContentCommonSupport.java:697) 
 at com.bea.portlet.adapter.scopedcontent.ScopedContentCommonSupport.processActionInternal(ScopedContentCommonSupport.java:142) 
 ...[생략]...
 at com.bea.netuix.nf.ControlTreeWalker.walkRecursive(ControlTreeWalker.java:334)
 

제가 복사한 sqljdbc4.jar 파일이 너무 최신 버전인 것 같습니다. 그렇다고 어떤 버전이 필요하다는 것도 없고... 휴... 웹 검색을 해도 (제가 못 찾은 건지도 모르겠지만) 별다르게 어떤 버전의 파일을 받아야 한다는 글이 없더군요. 그래서, 이전 버전의 것으로 다시 다운로드해서 테스트해 보았습니다.

Microsoft SQL Server JDBC 드라이버 2.0
; http://www.microsoft.com/downloads/ko-kr/details.aspx?FamilyID=99B21B65-E98F-4A61-B811-19912601FDC9

특이하게도 위의 링크에서 다운로드할 수 있는 파일은 HTML 문서인데, 그 파일을 웹 브라우저로 보면 문서의 마지막에 다운로드 할 수 있는 링크가 제공됩니다.

어쨌든, 위의 버전을 설치해도 역시 같은 오류가 발생해서 하나 더 내려갔습니다.

Microsoft SQL Server 2005 JDBC 드라이버 1.2 
; http://www.microsoft.com/downloads/ko-kr/details.aspx?FamilyID=C47053EB-3B64-4794-950D-81E1EC91C1BA

위의 jar 파일명은 "sqljdbc.jar"이어서 CLASSPATH에 다시 파일명을 변경해서 등록해 주고 테스트를 해봤는데... 오~~~ ^^ 이제서야 성공을 했습니다. 즉, WebLogic 10.0에는 JDBC 1.2를 등록해야 한다는 것입니다. (어쨌든 WebLogic이랑 SQL Server는 그다지 친한 것 같지는 않습니다. ^^)




마지막으로 몇 가지 시행착오를 설명하고 이 글을 마쳐야 겠습니다.

우선, 다음과 같은 오류를 만났다면?

Connection test failed. 

[BEA][SQLServer JDBC Driver][SQLServer]Login failed for user 'weblogic'.
weblogic.jdbc.base.BaseExceptions.createException(Unknown Source)
weblogic.jdbc.base.BaseExceptions.getException(Unknown Source)
...[생락]...
java.lang.reflect.Method.invoke(Method.java:592)
org.apache.beehive.netui.pageflow.FlowController.invokeActionMethod(FlowController.java:870)
org.apache.beehive.netui.pageflow.FlowController.getActionMethodForward(FlowController.java:809)

이전에도 강조했지만, JDBC Data Source 등록 과정에서 자꾸만 바뀌는 SQL 서버 보안 계정 및 암호를 재입력하지 않은 체 등록해서 발생하는 문제입니다. 다시 주의해서 등록해 주시면 정상적으로 문제가 해결될 것입니다.

다음으로, Target 설정 후 "Activate Changes" 버튼을 누를 때 다음과 같은 오류가 발생하는 경우가 있다면?

An error occurred during activation of changes, please see the log for details.

weblogic.application.ModuleException:

weblogic.common.ResourceException: Could not create pool connection. The DBMS driver exception was: No Configuration was registered that can handle the configuration named JDBC_DRIVER_01


위의 오류 메시지와 함께 '웹 로직을 실행하고 있는 cmd 콘솔' 화면에는 다음과 같은 오류가 보일 텐데요.

<2011. 10. 1 오전 11시 23분 17초 KST> <Error> <Console> <BEA-240003> <Console encountered the following error weblogic.application.ModuleException:
        at weblogic.jdbc.module.JDBCModule.prepare(JDBCModule.java:289)
        at weblogic.application.internal.flow.ModuleListenerInvoker.prepare(ModuleListenerInvoker.java:93)
        at weblogic.application.internal.flow.DeploymentCallbackFlow$1.next(DeploymentCallbackFlow.java:360)
        ...[생략]...

역시, 해당 Data Source를 삭제하고 다시 등록하세요. (계정/암호를 재입력하는 것 잊지 마시고.)




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







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

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

비밀번호

댓글 작성자
 



2012-10-25 08시18분
[달콤한녀석] 여기에서 새로 user/pw 넣어주는것은 아마도 "알패스"와 같은 자동 로그인 기능을 사용하는 툴을 사용하셔서 그런것으로 보여집니다.
[guest]
2012-10-25 12시40분
그럴 수도 있겠군요. ^^ 다음에 기회되면 한 번 더 확인을 해봐야되겠습니다.
정성태

... 46  47  48  49  50  51  52  [53]  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12323정성태9/11/20209723오류 유형: 649. Copy Database Wizard - The job failed. Check the event log on the destination server for details.
12322정성태9/11/202010932개발 환경 구성: 513. Azure VM의 RDP 접속 위치 제한 [1]
12321정성태9/11/20208993오류 유형: 648. netsh http add urlacl - Error: 183 Cannot create a file when that file already exists.
12320정성태9/11/202010153개발 환경 구성: 512. RDP(원격 데스크톱) 접속 시 비밀 번호를 한 번 더 입력해야 하는 경우
12319정성태9/10/20209945오류 유형: 647. smigdeploy.exe를 Windows Server 2016에서 실행할 때 .NET Framework 미설치 오류 발생
12318정성태9/9/20209364오류 유형: 646. OpenVPN - "TAP-Windows Adapter V9" 어댑터의 "Network cable unplugged" 현상
12317정성태9/9/202011726개발 환경 구성: 511. Beats용 Kibana 기본 대시 보드 구성 방법
12316정성태9/8/202010128디버깅 기술: 170. WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드
12315정성태9/7/202012450개발 환경 구성: 510. Logstash - FileBeat을 이용한 IIS 로그 처리 [2]
12314정성태9/7/202011085오류 유형: 645. IIS HTTPERR - Timer_MinBytesPerSecond, Timer_ConnectionIdle 로그
12313정성태9/6/202012175개발 환경 구성: 509. Logstash - 사용자 정의 grok 패턴 추가를 이용한 IIS 로그 처리
12312정성태9/5/202016048개발 환경 구성: 508. Logstash 기본 사용법 [2]
12311정성태9/4/202011302.NET Framework: 937. C# - 간단하게 만들어 보는 리눅스의 nc(netcat), json_pp 프로그램 [1]
12310정성태9/3/202010576오류 유형: 644. Windows could not start the Elasticsearch 7.9.0 (elasticsearch-service-x64) service on Local Computer.
12309정성태9/3/202010317개발 환경 구성: 507. Elasticsearch 6.6부터 기본 추가된 한글 형태소 분석기 노리(nori) 사용법
12308정성태9/2/202011595개발 환경 구성: 506. Windows - 단일 머신에서 단일 바이너리로 여러 개의 ElasticSearch 노드를 실행하는 방법
12307정성태9/2/202012333오류 유형: 643. curl - json_parse_exception / Invalid UTF-8 start byte
12306정성태9/1/202010474오류 유형: 642. SQL Server 시작 오류 - error code 10013
12305정성태9/1/202011396Windows: 172. "Administered port exclusions"이 아닌 포트 범위 항목을 삭제하는 방법
12304정성태8/31/202010334개발 환경 구성: 505. 윈도우 - (네트워크 어댑터의 우선순위로 인한) 열거되는 IP 주소 순서를 조정하는 방법
12303정성태8/30/202010535개발 환경 구성: 504. ETW - 닷넷 프레임워크 기반의 응용 프로그램을 위한 명령행 도구 etrace 소개
12302정성태8/30/202010404.NET Framework: 936. C# - ETW 관련 Win32 API 사용 예제 코드 (5) - Private Logger파일 다운로드1
12301정성태8/30/202010734오류 유형: 641. error MSB4044: The "Fody.WeavingTask" task was not given a value for the required parameter "IntermediateDir".
12300정성태8/29/202010105.NET Framework: 935. C# - ETW 관련 Win32 API 사용 예제 코드 (4) CLR ETW Consumer파일 다운로드1
12299정성태8/27/202011041.NET Framework: 934. C# - ETW 관련 Win32 API 사용 예제 코드 (3) ETW Consumer 구현파일 다운로드1
12298정성태8/27/202010756오류 유형: 640. livekd - Could not resolve symbols for ntoskrnl.exe: MmPfnDatabase
... 46  47  48  49  50  51  52  [53]  54  55  56  57  58  59  60  ...