Details
-
Bug
-
Status: Resolved
-
Minor
-
Resolution: Fixed
-
2.18.3
-
None
-
Windows 7 x64
-
Unknown
Description
When creating a route as follows:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:camel="http://camel.apache.org/schema/spring" xmlns:context="http://www.springframework.org/schema/context" xmlns:util="http://www.springframework.org/schema/util" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd http://camel.apache.org/schema/spring http://camel.apache.org/schema/spring/camel-spring.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.5.xsd"> <bean id="zipFileDataFormat" class="org.apache.camel.dataformat.zipfile.ZipFileDataFormat"> <property name="usingIterator" value="true" /> </bean> <camelContext xmlns="http://camel.apache.org/schema/spring" streamCache="true"> <route> <from uri="file:C:/camelTest/in" /> <unmarshal ref="zipFileDataFormat" /> <split streaming="true"> <simple>${body}</simple> <log loggingLevel="INFO" message="$simple{header.zipFileName}" /> <to uri="file:C:/camelTest/xml" /> </split> <log loggingLevel="INFO" message="$simple{file:name} Succesful processed" /> </route> </camelContext> </beans>
the renaming of the file fails with
Renaming file from 'C:\camelTest\in\20161201T0030Z_1D_BE00_EQ.zip' to 'C:\camelTest\in\.camel\20161201T0030Z_1D_BE00_EQ.zip' failed: Cannot delete file 'C:\camelTest\in\20161201T0030Z_1D_BE00_EQ.zip' after copy succeeded
The file stays in input folder and gets processed over and over again.
Investigation
Problem only occurs if:
- you try to move the file at the end of the exchange (not with noop but with delete, for example)
- if ZipFile dataformat is used (not with ZipSplitter)
- if usingIterator is true (not if false and Zip file with 1 entry)
It's because in org.apache.camel.dataformat.zipfile.ZipIterator constructor:
InputStream inputStream = inputMessage.getBody(InputStream.class);
will create a new input stream instead of using the one already opened: inputStream parameter when using org.apache.camel.dataformat.zipfile.ZipFileDataFormat#unmarshal.
This one won't be closed and you won't be able to release the resource unless you kill the process.
So, two solutions:
- close the inputStream parameter in org.apache.camel.dataformat.zipfile.ZipFileDataFormat#unmarshal before using ZipIterator constructor
- use inputStream parameter instead of creating a new one when using dataformat (that's the implementation provided in the pull request)
Attachments
Issue Links
- is a clone of
-
CAMEL-11120 Camel ZipFile does cannot move file after succesful processing
- Resolved
- links to