>데이터 베이스 >MySQL 튜토리얼 >연결 풀을 사용하는 경우에도 JDBC 연결을 닫아야 합니까?

연결 풀을 사용하는 경우에도 JDBC 연결을 닫아야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-07 11:58:11718검색

Should I Close JDBC Connections Even When Using a Connection Pool?

풀링 구성에서 JDBC 연결 닫기

연결 풀을 사용할 때 사용이 끝나면 연결을 닫는 것이 중요합니다. 풀링의 목적을 부정한다는 일반적인 오해에도 불구하고. 연결을 닫으면 효과적으로 풀로 반환됩니다. 이를 통해 풀은 리소스를 관리하고 실제 연결을 닫을지 아니면 후속 getConnection() 호출에 재사용할지 결정할 수 있습니다.

그러나 제공된 코드 스니펫에서는 풀링된 연결과 풀링된 연결 간에 전환을 시도합니다. DriverManager에서 직접 연결합니다. 이 관행은 권장되지 않습니다. 대신, 애플리케이션 초기화 중에 단일 DataSource를 설정하고 이에 전적으로 의존하여 연결을 검색하십시오. 이렇게 하면 동기화, null 검사의 필요성과 런타임에 어떤 연결 방법이 호출되는지에 대한 불확실성이 사라집니다.

하이브리드 방법에서 파생된 연결 닫기

예 , 제시한 하이브리드 방법으로 반환된 연결을 닫아야 합니다. 연결을 획득하는 데 사용된 방법에 관계없이 JDBC 자원을 역순으로 닫는 일반 원칙이 그대로 적용됩니다. 이렇게 하면 적절한 리소스 정리가 보장되고 리소스 고갈이 방지됩니다.

연결 확보를 위한 표준 사례

일반적으로 JDBC 연결 확보에 선호되는 접근 방식은 다음과 같습니다.

  1. 응용 프로그램 중 한 번 DataSource 초기화
  2. 애플리케이션의 전체 수명 동안 DataSource에서 getConnection()을 반복적으로 호출합니다.

이 간단하고 간단한 접근 방식은 하이브리드 연결 획득 방법과 관련된 복잡성과 불확실성을 제거합니다.

추가 리소스

  • 멀티 스레드 시스템에서 정적 java.sql.Connection 인스턴스를 사용하는 것이 안전한가요?
  • JDBC 연결 풀링을 사용하고 있습니까?

위 내용은 연결 풀을 사용하는 경우에도 JDBC 연결을 닫아야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.