글
톰켓 4.x 버젼까지는 됬는데 5.x 버젼으로 가면서 셋팅법이 약간 바꼇다.;
이거때문에 좀 애먹었다..ㅡ.ㅡ;
1. MYSQL 드라이버를 받아서 설치하기;
- 이거 잘못넣어놓으니까 자꾸 클래스를 못찾는 에러를 발생한다. 톰켓루트의 shared/lib 이나 애플리케이션루트의 WEB-INF/lib 디렉토리에 넣으면 컴파일은 되나 실행하면 클래스를 못찾는다는것을 명심하자.
- 가장 귀찮지만 좋은방법은 환경변수에 클래스패스를 걸어서 따로 모아두는거다.(귀찮다.)
- 두번째 방법은 톰켓루트 common/lib 에 넣어놓는거다. 이거는 클래스패스 안걸어도 톰켓이 알아서 찾아간다. (난 이걸로 쓰겠다.)
- 마지막으로 가장 무식한방법인 jre/lib/ext 에 넣는 방법이다. (이건 대략 비추)
2. server.xml 설정하기;
- 이게 문제다. 5.x 버젼으로 오면서 약간 바꼇다. 확인해보자.
- 아래것을 <Context> 태그 사이에 넣어주면 된다.
- 먼저 기존것은 다음과 같다.
<Resource auth="Container" name="jdbc/mysql" type="javax.sql.DataSource"/>
<ResourceParams name="jdbc/mysql">
<parameter>
<name>factory</name>
<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
</parameter>
<parameter>
<name>url</name>
<value>jdbc:mysql://localhost:3306/cranix</value>
</parameter>
<parameter>
<name>driverClassName</name>
<value>com.mysql.jdbc.Driver</value>
</parameter>
<parameter>
<name>maxIdle</name>
<value>10</value>
</parameter>
<parameter>
<name>maxActive</name>
<value>20</value>
</parameter>
<parameter>
<name>maxWait</name>
<value>-1</value>
</parameter>
<parameter>
<name>minEvictableIdleTimeMillis</name>
<value>600000</value>
</parameter>
<parameter>
<name>username</name>
<value>ID</value>
</parameter>
<parameter>
<name>password</name>
<value>PASS</value>
</parameter>
</ResourceParams>
- 이것이 아래와같이 변경됬다.
<Resource
name="jdbc/mysql"
auth="Container"
type="javax.sql.DataSource"
username="[ID]"
password="[PASS]"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/cranix"
/>
- 짧아져서 좋긴한데.. 몇시간동안 헤멨다 (역시 네이버형님은 모르는게 없다.!)
3. web.xml 설정하기
- 이건 변함없다.
<resource-ref>
<description>Use for valuation systems DataSource</description>
<res-ref-name>jdbc/mysql</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
4. 커넥션 확인하기!
- JNDI 를 써서 커넥션을 확인해보자.
- 먼저 아래와같이 JNDI 를 컨트롤하는 클래스를 하나만들자.
- JndiConnectionManager.java
package cranix.common.util;
import java.sql.*;
import javax.naming.*;
import javax.sql.DataSource;
import java.util.Hashtable;
public class JndiConnectionManager {
private static JndiConnectionManager jcm = null;
private Hashtable<String, DataSource> table = null;
private Context initContext = null;
private JndiConnectionManager() throws Exception {
table = new Hashtable<String, DataSource>();
initContext = (Context)new InitialContext().lookup("java:comp/env/");
}
private DataSource getDataSource(String name) throws Exception {
DataSource ds = table.get(name);
if (ds == null) {
ds = (DataSource)initContext.lookup(name);
table.put(name, ds);
}
return ds;
}
public static JndiConnectionManager getInstance() throws Exception {
if (jcm == null)
jcm = new JndiConnectionManager();
return jcm;
}
public Connection openConnection(String name) throws Exception {
DataSource ds = getDataSource(name);
Connection conn = ds.getConnection();
return conn;
}
public void closeConnection(Connection conn) throws Exception {
conn.close();
}
}
- 다음 위 클래스를 쓰는 jndiTest.jsp 파일을 만든다.
<%@page import="java.sql.Connection,cranix.common.util.JndiConnectionManager" %>
<%
JndiConnectionManager jcm = JndiConnectionManager.getInstance();
Connection conn = jcm.openConnection("jdbc/mysql");
jcm.closeConnection(conn);
%>
success!
- 이제 실행해보자!
- 예외가 발생하지 않는다면 성공!
'웹 > Jsp' 카테고리의 다른 글
jsp 직접실행 막기 (53) | 2007.12.12 |
---|---|
JSP 페이지를 열때마다 자동으로 캐시 지우기 (42) | 2007.03.18 |
스트러츠 2.0 (92) | 2006.12.16 |
RECENT COMMENT