PHPExcel을 사용하여 Excel 문서를 생성하면 더 많은 메모리가 소모됩니다. 때로는 메모리 소모를 방지하기 위해 루프를 통해 큰 데이터를 여러 개의 작은 Excel 문서로 나누어 저장해야 할 수도 있습니다.
그러나 PHPExcel에는 순환 참조가 있습니다(최신 1.6.5 버전에서는 이 문제가 해결되지 않은 것 같습니다). 여러 Excel 문서 생성 작업을 완료하기 위해 http 요청 중에 PHPExcel 및 PHPExcel_Writer_Excel5 개체 인스턴스가 여러 번 반복적으로 생성되는 경우 생성된 객체 인스턴스는 http 요청이 끝나기 전에 시간 내에 해제될 수 없으므로 메모리 누수가 발생합니다.
해결책은 PHPExcel_Worksheet 클래스에 메소드를 추가하는 것입니다:
공개 함수 Destroy() {
foreach($this->_cellCollection as $index => $dummy) {
$this->_cellCollection[$index] = null;
}
}
그리고 PHPExcel 클래스에 메서드를 추가하세요.
공개 함수 Destroy() {
foreach($this->_workSheetCollection as $index => $dummy) {
$this->_workSheetCollection[$index]->Destroy();
$this->_workSheetCollection[$index] = null;
}
}
그런 다음 순환 참조 문제를 처리하기 위해 리소스 재활용이 필요한 경우 PHPExcel::Destroy()를 명시적으로 호출합니다. __destruct() 메서드는 객체가 해제될 준비가 된 것으로 간주될 때만 호출되므로 __destruct()에서는 순환 참조 처리를 수행할 수 없습니다.