메뉴 건너뛰기

조회 수 7720 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

WAS를 갈아타고 작업할 때 마다 항상 잊어버린다. 그리고 이놈의 tomcat은 버전마다 이런 기본 설정 방법이 달라지니...
점점 떨어지는 기억력은 어쩔 수 없으니 블로그에 의지하고 남기는 수 밖에...
---

Tomcat에서 Datasource 설정하기
Tomcat에서는 JNDI 리소스를 등록하는 방법이 크게 2가지가 있다. 하나는 모든 web context가 사용할 수 있는global 리소스이고 다른 하나는 해당 context에만 적용되는 리소스이다.

Global 리소스 등록방법
${CATALINA_HOME}/conf/server.xml에 다음과 같이 추가

   <Server port="8005" shutdown="SHUTDOWN"> 
   ... 
  <GlobalNamingResources> 
    <!-- Editable user database that can also be used by 
         UserDatabaseRealm to authenticate users 
    --> 
    <Resource name="UserDatabase" auth="Container" 
              type="org.apache.catalina.UserDatabase" 
              description="User database that can be updated and saved" 
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory" 
              pathname="conf/tomcat-users.xml" /> 
    
    <Resource name="jdbc/OracleDS" auth="Container" type="javax.sql.DataSource" 
          username="xxx" 
          password="xxx" 
          driverClassName="oracle.jdbc.driver.OracleDriver" 
          url="jdbc:oracle:thin:@localhost:1521:XE" />
 
          
  </GlobalNamingResources> 
 ...

각 web context에서 global 리소스를 사용하기 위해서는 각 context의 <ResourceLink/> 태그로 연결하여야 한다. 다음은 모든 context에 연결하는 방법이다.

${CATALINA_HOME}/conf/context.xml에 다음과 같이 추가

 <Context> 
    <WatchedResource>WEB-INF/web.xml</WatchedResource> 
    <ResourceLink 
            name="jdbc/OracleDS" 
            global="jdbc/OracleDS" 
            type="javax.sql.DataSource" 
          /> 
...


Context 리소스 등록방법
tomcat 6.x에서는 각 WAR 디렉토리의 /META-INF/context.xml 파일에 해당 context 설정 정보를 담고 있다. 즉 WAR 파일 내에 context.xml 이 있어야 한다. 편하긴 한데...

예) bcf가 context라면

${CATALINA_HOME}/webapps/bcf/META-INF/context.xml 에 다음과 같이 추가

<Context antiResourceLocking="false" privileged="true"> 
<Resource name="jdbc/OracleDS" auth="Container" type="javax.sql.DataSource" 
          username="xxx" 
          password="xxx" 
          driverClassName="com.mysql.jdbc.Driver" 
          url="jdbc:mysql://localhost:3306/bcf" />
 
< /Context>


JNDI로 접근하기
다른 JNDI 룩업과 마찬가지로 다음과 같은 이름로 접근하면 된다. 그냥 jdbc/OracleDS 이런식으로는 접근할 수 없다. 

java:comp/env/jdbc/OracleDS


정리
Context 리소스 등록방법이 context.xml을 war/MET-INF 밑에 넣으면 되기 때문에 더 편하기는 한데 war에 저 파일이 배포되어야해서 좀 찜찜하다. (datasource 정보가 WAR 형상관리되어야 한다?)

따라서 운영환경에서는 global 리소스를 이용하는 방법이 나을 듯 하다. (역시 비밀번호는 노출이 되는군 ㅠㅠ)


  1. No Image 11Mar
    by 조쉬
    2017/03/11 Views 7720 

    Tomcat 6에 Datasource 설정하기

  2. tomcat - server.xml 설정

  3. [CentOS 6.5] Virtual Box를 이용한 CentOS 6.5 설치

  4. [CentOS 6.5] SSH,TELNET, FTP 설치 및 운용

  5. [CentOS 6.5] JDK (JAVA) 설치

  6. [CentOS 6.5] Tomcat 설치 및 구동

  7. No Image 09Mar
    by
    2017/03/09 Views 8516 

    TOMCAT/사이트 여러개 운영

  8. No Image 03Feb
    by
    2017/02/03 Views 7947 

    SSH / FTP 등 기본 접속환경 설정(리눅스 / 솔라리스)

  9. No Image 03Feb
    by
    2017/02/03 Views 8077 

    솔라리스 10 (Telnet/FTP/SSH) 설정

  10. 아파치 디렉토리 보이는 것 막기

  11. No Image 02Feb
    by
    2017/02/02 Views 7944 

    아파치 로그(Apache Log) 관리법

  12. crontab 을 이용한 PHP 스케줄링 작업

  13. No Image 02Feb
    by
    2017/02/02 Views 7278 

    crontab 설정 방법

  14. No Image 30Dec
    by
    2016/12/30 Views 7158 

    apachec rewrite 사용하기 // www 강제 사용 // HTTP to HTTPS // 특정경로만 HTTP

  15. No Image 30Dec
    by
    2016/12/30 Views 8774 

    APACHE, OHS 400 웹로직 연동후 특정 작업에 400 error

  16. No Image 22Dec
    by
    2016/12/22 Views 8884 

    netstat 사용법

  17. No Image 22Dec
    by
    2016/12/22 Views 7220 

    mod_rewrite 예제

  18. No Image 22Nov
    by
    2016/11/22 Views 8629 

    아파치 웹로직 연동(Virtual Host)

  19. No Image 22Nov
    by
    2016/11/22 Views 8897 

    Apache 2.2.17 + WebLogic 10.3.3 연동하기

  20. CentOS6.6+httpd2.4.16+Mariadb10.0.20+php5.6.11 Source 설치....

Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 12 Next
/ 12

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved