집 >데이터 베이스 >MySQL 튜토리얼 >데이터베이스 상호 작용에서 \'연결이 닫힌 후에는 작업이 허용되지 않습니다\' 예외를 처리하는 방법은 무엇입니까?
연결 종료 예외 후 작업이 허용되지 않습니다
설명:
이 예외는 다음과 같은 경우에 발생합니다. 데이터베이스에 대한 연결이 닫힌 후 작업을 실행하려고 시도합니다. 근본적인 원인은 연결 시간 초과 문제인 경우가 많습니다.
가능한 원인:
해결책:
연결 풀링
Hibernate의 기본 연결 풀 대신 타사 연결 풀링 라이브러리가 사용되는지 확인하십시오. 이는 프로덕션 환경에 적합하지 않기 때문입니다. C3P0 또는 DBCP 사용을 고려하세요.
서버측 시간 초과 구성
연결이 조기에 종료되는 것을 방지하려면 MySQL의 wait_timeout 매개변수를 더 높은 값으로 조정하세요.
클라이언트 측 시간 초과 구성
연결 수명을 연장하려면 연결 풀의 maxConnectionAge 및 maxIdleTime 속성을 늘립니다.
C3P0 구성 예:
<code class="xml"><property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> <property name="c3p0.acquire_increment">1</property> <property name="c3p0.idle_test_period">100</property> <!-- seconds --> <property name="c3p0.max_size">100</property> <property name="c3p0.max_statements">0</property> <property name="c3p0.min_size">10</property> <property name="c3p0.timeout">1800</property> <!-- seconds --> </code>
추가 참고 사항:
"c3p0.testConnectionOnCheckout=true" 속성을 사용하기 전에 연결을 테스트하도록 설정할 수 있지만 이는 성능에 영향을 미칠 수 있습니다.
위 내용은 데이터베이스 상호 작용에서 \'연결이 닫힌 후에는 작업이 허용되지 않습니다\' 예외를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!