You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@pdfbox.apache.org by "Maruan Sahyoun (JIRA)" <ji...@apache.org> on 2016/07/30 10:38:20 UTC

[jira] [Comment Edited] (PDFBOX-3443) use org.apache.pdfbox.multipdf.Splitter#split(), Exception in thread "main" java.lang.OutOfMemoryError: GC overhead limit exceeded

    [ https://issues.apache.org/jira/browse/PDFBOX-3443?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15400628#comment-15400628 ] 

Maruan Sahyoun edited comment on PDFBOX-3443 at 7/30/16 10:37 AM:
------------------------------------------------------------------

that's a known issue. See PDFBOX-3280. Either use 2.0.1 or 2.0.3-SNAPSHOT


was (Author: msahyoun):
that's a known issue. See PDFBox-3280. Either use 2.0.1 or 2.0.3-SNAPSHOT

> use org.apache.pdfbox.multipdf.Splitter#split(), Exception in thread "main" java.lang.OutOfMemoryError: GC overhead limit exceeded
> ----------------------------------------------------------------------------------------------------------------------------------
>
>                 Key: PDFBOX-3443
>                 URL: https://issues.apache.org/jira/browse/PDFBOX-3443
>             Project: PDFBox
>          Issue Type: Bug
>          Components: PDModel
>    Affects Versions: 2.0.2
>         Environment: Windows 7/Java 8
>            Reporter: kohdai
>
> I use org.apache.pdfbox.multipdf.Splitter#split()
> but OOM occured when I try to split large size pdf(20Mb, 100pages).
> = =
> PDDocument document = PDDocument.load(large_size.pdf);
> Splitter splitter = new Splitter();
> List<PDDocument> splittedDocuments = splitter.split(document);
> = =
> Exception in thread "main" java.lang.OutOfMemoryError: GC overhead limit exceeded
> 	at org.apache.pdfbox.io.ScratchFileBuffer.addPage(ScratchFileBuffer.java:132)
> 	at org.apache.pdfbox.io.ScratchFileBuffer.ensureAvailableBytesInPage(ScratchFileBuffer.java:184)
> 	at org.apache.pdfbox.io.ScratchFileBuffer.write(ScratchFileBuffer.java:203)
> 	at org.apache.pdfbox.io.RandomAccessOutputStream.write(RandomAccessOutputStream.java:58)
> 	at java.io.FilterOutputStream.write(Unknown Source)
> 	at java.io.FilterOutputStream.write(Unknown Source)
> 	at org.apache.pdfbox.io.IOUtils.copy(IOUtils.java:68)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:119)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:99)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:125)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:99)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:136)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:136)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:136)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:99)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:108)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:136)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:99)
> 	at org.apache.pdfbox.multipdf.PDFCloneUtility.cloneForNewDocument(PDFCloneUtility.java:136)
> 	at org.apache.pdfbox.pdmodel.PDDocument.importPage(PDDocument.java:525)
> 	at org.apache.pdfbox.multipdf.Splitter.processPage(Splitter.java:206)
> 	at org.apache.pdfbox.multipdf.Splitter.processPages(Splitter.java:128)
> 	at org.apache.pdfbox.multipdf.Splitter.split(Splitter.java:63)
> 	at main.PDFConvert2Chapter.convert(PDFConvert2Chapter.java:89)
> 	at main.PDFConvert2Chapter.main(PDFConvert2Chapter.java:39)
> = =
> PDFBox 2.0.2 OOM occured
> PDFBox 2.0.1 No problem
> I think that code is wrong.
> org.apache.pdfbox.pdmodel.PDDocument#importPage() tag:2.0.2
> public PDPage importPage(PDPage page) throws IOException
> {
>     PDFCloneUtility cloner = new PDFCloneUtility(this);
>     COSBase pageBase = cloner.cloneForNewDocument(page.getCOSObject());
>     PDPage importedPage = new PDPage((COSDictionary) pageBase, resourceCache);
>     addPage(importedPage);
>     return importedPage;
> }



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@pdfbox.apache.org
For additional commands, e-mail: dev-help@pdfbox.apache.org