close
  • 홈
  • :
  • 위치로그
  • :
  • 태그
  • :
  • 방명록
  • :
  • 관리자
  • :
  • 새글쓰기
블로그 이미지

이슬나라 [isulnara.com]
프로그램 관련 문의...
전체 (184)
자작 프로그램 (23)
EzIP (3)
IEPageSetup (3)
iSysInfoX (2)
메신저 알림이 (1)
ezSVC (1)
WebFTP (2)
iDebugX (1)
기타 (9)
버그 신고 (1)
이것저것.. (55)
WebFTP 게시판 (0)
팁 모음 (72)
linux (17)
프로그래밍 (35)
윈도우 (5)
네크워크 (7)
기타 (7)
윈도우 숨은.. (4)
터미널 서비스.. (1)
공개 웹하드 (1)
관리자 (0)
PC 원격제어.. (1)
NAS (25)
«   2010/09   »
일 월 화 수 목 금 토
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30    
IP nas WebFTP 아파치 putty FON emulator scp msn 알림이 sshd ftp Window 텍스트큐브 메신저 Prototype Points 강의 ShrinkToFit proftpd android 동영상 분할 및 병합 시리얼통신 DateCompare 류종택 CPUID REFERENCE_TIME location.href 콘솔프로그램 시놀로지 vnc
[NAS] Synology DS101...
[안드로이드] 스플래...
[android] android_wi...
이전 달의 파일을 특...
Synology FileStation...
저도 지금 테스트해보니...
isul / 09/08
IE8에 플래시 사용한 웹...
isul / 09/08
안녕하세요.. zbs-100은...
isul / 09/08
안드로이드에서도 시리얼...
isul / 09/08
안드로이드 기반에서 시...
소바 / 09/08
일반 어플리케이션을 서...
ㅇㅇ/ / 2009
사이코웨어 : nProtect,...
√ MIRiyA's AstraLog / 2008
웹페이지에서 인쇄시 머...
醉生夢死™ / 2006
웹페이지에서 MAC Addres...
날자~!! 날어~!! / 2005
 최근글 목록
 2010/09 [1]
 2010/08 [4]
 2010/07 [1]
 2010/06 [2]
 2010/05 [1]
넷하드
무료 원격제어 프로그램
바이러스제로
솔라리스 테크넷
스티브 맥코넬
파워해커
하얀나무's Story
Total of
331580 visitors
Today 192
Yesterday 270
 
글검색결과[jndi] : 1
2008/02/20  Tomcat 5.0.27 + SQL Server 환경에 DBCP(DataBase Connection Pool) 사용
     
 팁 모음/프로그래밍 
Tomcat 5.0.27 + SQL Server 환경에 DBCP(DataBase Connection Pool) 사용
Posted on 2008/02/20 14:25
 
 
 
 
1. jdbc 드라이버 파일 복사
SQL Server 2005용 jdbc 드라이버 파일 sqljdbc.jar를 c:\Program Files\tomcat\common\lib\에 복사
SQL Server 2000일 경우 msutil.jar, msbase.jar, mssqlserver.jar


2. server.xml 설정

파일 위치: c:\Program Files\tomcat\conf\server.xml

<Host name="localhost" debug="0" appBase="webapps"
unpackWARs="true" autoDeploy="true"
xmlValidation="false" xmlNamespaceAware="false">

<Context path="" docBase="X:\myAPP\source\jsp\FHMS\WEB_ROOT" debug="0" reloadable="true">
    <!-- FHMS DB Setting -->
    <Resource name="jdbc/fhms" auth="Container" type="javax.sql.DataSource"/>
    <ResourceParams name="jdbc/fhms">
    <parameter>
        <name>username</name>
        <value>webuser</value>
    </parameter>
    <parameter>
        <name>password</name>
        <value>adlf@reawt*d*</value>
    </parameter>
    <parameter>
      <name>driverClassName</name>
      <value>com.microsoft.sqlserver.jdbc.SQLServerDriver</value>
    </parameter>
    <parameter>
      <name>url</name>
      <value>jdbc:sqlserver://192.168.0.2:1433;databasename=fhms;SelectMethod=cursor;</value>
    </parameter>
    <parameter>
      <name>removeAbandoned</name>
      <value>true</value>
    </parameter>
    <parameter>
      <name>removeAbandonedTimeout</name>
      <value>60</value>
    </parameter>
    <parameter>
      <name>logAbandoned</name>
      <value>true</value>
    </parameter>
    <parameter>
      <name>maxActive</name>
      <value>25</value>
    </parameter>
    <parameter>
      <name>maxIdle</name>
      <value>10</value>
    </parameter>
    <parameter>
      <name>maxWait</name>
      <value>-1</value>
    </parameter>
    <parameter>
        <name>factory</name>
        <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
    </parameter>
    </ResourceParams>
    <ResourceLink name="jdbc/fhms" global="jdbc/fhms" type="javax.sql.DataSource"/>
</Context>

</Host>

SQL Server 2000 드라이버를 사용할 경우 위 내용 중 driverClassName와 url을 다음과 같이 수정
<parameter>
  <name>driverClassName</name>
  <value>com.microsoft.jdbc.sqlserver.SQLServerDriver</value>
</parameter>

<parameter>
  <name>url</name>
  <value>jdbc:microsoft:sqlserver://192.168.0.2:1433;databasename=fhms;SelectMethod=cursor;</value>
</parameter>


*. 참고: 아래 사항은 <Context></Context> 사이에 넣지 않고, <GlobalNamingResources>안에 넣어도 됨
<Resource name="jdbc/fhms" auth="Container" type="javax.sql.DataSource"/>
                                    ....
</ResourceParams>



3. 사용 예

xxx.jsp의 소스 코드

<%@ page import="java.sql.*, javax.naming.*, javax.sql.*, java.util.*" contentType="text/html;charset=euc-kr" %>
<%
try
{
    Context ctx = new InitialContext();
    DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/fhms");
    Connection conn = ds.getConnection();

    String sid = "A3DE42F";
    PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM sensor WHERE sid = ?");
    pstmt.setString(1,  sid );

    ResultSet rs = pstmt.executeQuery();

    while (rs.next())
    {
        out.println(rs.getString("name"));
    }

    if (pstmt != null)
        pstmt.close();
    if (rs != null)
        rs.close();
    if (conn != null)
        conn.close();
}
catch(Exception e)
{
    out.println(e);
}


4. 에러 메시지에 따른 문제 해결 방법

org.apache.commons.dbcp.SQLNestedException: Cannot load JDBC driver class 'com.microsoft.sqlserver.jdbc.SQLServerDriver'
-> sqljdbc.jar을 c:\Program Files\tomcat\common\lib\에 복사


javax.naming.NameNotFoundException: Name jdbc is not bound in this Context
-> server.xml
        <Context path="" docBase="X:\myAPP\source\jsp\FHMS\WEB_ROOT" debug="0" reloadable="true">
            <ResourceLink name="jdbc/fhms" global="jdbc/fhms" type="javax.sql.DataSource"/>
        </Context>

참고 웹페이지
1. http://tong.nate.com/bbottlejo/43172210
2. http://kin.naver.com/detail/detail.php?d1id=1&dir_id=10106&eid=Ppn9AJtqrH2Aj0jRlvKNHj1k9CIND1EQ&qb=bG9va3VwKCJqYXZhOg==
3. http://annehouse.tistory.com/249
4. http://blog.naver.com/jyoung96?Redirect=Log&logNo=110001673012


Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
이올린에 북마크하기(0) 이올린에 추천하기(0)
jndi, SQL Server, tomcat
Trackback [0] : Comment [0]
TrackbackAddress
http://isulnara.com/tt/trackback/156
SecretComment
  1