대규모 MySQL 결과 세트 스트리밍
문제 설명
대규모 MySQL 테이블을 로드할 때 Spring 애플리케이션, 드라이버가 전체 테이블을 메모리에 로드하려는 시도로 인해 OutOfMemory 예외가 발생합니다. 가져오기 크기를 Integer.MIN_VALUE로 설정했음에도 불구하고 ResultSet를 닫으면 정지 문제가 발생합니다. 작은 테이블의 경우에도 중단이 지속되어 연결이 닫히지 않아 다음과 같은 스택 추적이 발생합니다.
[Stack trace of the hang inserted here]
해결 방법
가져오기 크기만 설정하는 것만으로는 충분하지 않습니다. MySQL JDBC 드라이버에는 특정 명령문 생성 방법이 필요합니다.
stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_READ_ONLY); stmt.setFetchSize(Integer.MIN_VALUE);
주의 사항 및 의미
이 접근 방식에는 몇 가지 주의 사항이 있습니다.
추가 고려 사항
OutOfMemory 예외가 지속되면 구현을 고려하세요. 과도한 메모리 할당을 피하기 위해 데이터베이스에서 검색된 데이터를 즉시 처리합니다. 이를 위해서는 상당한 코드 재구성과 다른 흐름 제어 접근 방식이 필요할 수 있습니다.
위 내용은 OutOfMemory 오류 없이 Spring에서 대규모 MySQL 결과 세트를 효율적으로 스트리밍하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!