연결 풀링 사용

Microsoft SQL Server JDBC 드라이버는 Java Platform, Enterprise Edition 5 (Java EE 5) 연결 풀링을 지원합니다. 미들웨어 공급업체가 제공하며 JDBC 3.0과 호환되는 모든 연결 풀링 구현에 참여할 수 있도록 JDBC 드라이버는 JDBC 3.0 필수 인터페이스를 구현합니다. Java EE 5 응용 프로그램 서버와 같은 미들웨어는 대개 호환되는 연결 풀링 기능을 제공합니다. JDBC 드라이버는 이러한 환경에서 풀링된 연결에 참여합니다.

참고

JDBC 드라이버는 Java EE 5 연결 풀링을 지원하지만 자체 풀링 구현을 제공하지는 않습니다. 대신 JDBC 드라이버는 타사 Java 응용 프로그램 서버를 통해 연결을 관리합니다.

연결 풀링을 구현하는 데 필요한 클래스는 다음과 같습니다.

클래스 구현 설명

com.microsoft.sqlserver.jdbc.SQLServerXADataSource

javax.sql.ConnectionPoolDataSource and javax.sql.XADataSource

SQLServerXADataSource 클래스는 모든 JDBC 3.0 풀링과 XA 인터페이스를 구현하므로 Java EE 5 서버가 필요한 모든 경우에 이 클래스를 사용하는 것이 좋습니다.

com.microsoft.sqlserver.jdbc.SQLServerConnectionPoolDataSource

javax.sql.ConnectionPoolDataSource

이 클래스는 Java EE 5 응용 프로그램 서버에서 해당 연결 풀을 물리적 연결로 채울 수 있도록 하는 연결 팩토리입니다. Java EE 5 공급업체의 구성에 javax.sql.ConnectionPoolDataSource를 구현하는 클래스가 필요한 경우 클래스 이름을 SQLServerConnectionPoolDataSource로 지정합니다. SQLServerXADataSource 클래스는 풀링 및 XA 인터페이스를 모두 구현하고 더 많은 Java EE 5 서버 구성에서 검증되었으므로 일반적으로 이 클래스를 사용하는 것이 좋습니다.

JDBC 응용 프로그램 코드에서 풀링의 이점을 극대화하려면 항상 연결을 명시적으로 닫아야 합니다. 응용 프로그램에서 연결을 명시적으로 닫으면 풀링 구현은 연결을 바로 다시 사용할 수 있습니다. 연결을 닫지 않으면 다른 응용 프로그램에서 이를 다시 사용할 수 없습니다. 응용 프로그램에서는 finally 구문을 사용하여 예외가 발생하더라도 풀링된 연결이 닫히도록 할 수 있습니다.

참고

JDBC 드라이버는 현재 연결을 풀에 반환할 때 sp_reset_connection 저장 프로시저를 호출하지 않습니다. 대신 JDBC 드라이버는 타사 Java 응용 프로그램 서버를 통해 연결을 원래 상태로 되돌립니다.

참고

관련 자료

JDBC 드라이버로 SQL Server에 연결