[
https://issues.apache.org/jira/browse/OLINGO-937?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15249303#comment-15249303
]
Michael Bolz commented on OLINGO-937:
-------------------------------------
Hi [~baylej],
The community has to thank you for improving the library ;o)
The [merge into the
master|https://git1-us-west.apache.org/repos/asf?p=olingo-odata2.git;a=commit;h=1c81f7ba8b92ede9f4df7eadf148b3539ebfd9e5]
is done hence I close this issue and with next release the improvement is
available.
Best Regards, Michael
> Avoid call to ServiceLoader on each request
> -------------------------------------------
>
> Key: OLINGO-937
> URL: https://issues.apache.org/jira/browse/OLINGO-937
> Project: Olingo
> Issue Type: Improvement
> Components: odata2-core
> Affects Versions: V2 2.0.6
> Reporter: Jonathan Bayle
> Assignee: Michael Bolz
> Labels: performance, xml
>
> Dear Olingo developers,
> New instances of XMLInputFactory, Transformer and XMLStreamWriter are created
> on each request that parses/produces XML documents.
> These instances are obtained through the ServiceLoader class, which is known
> for being slow.
> See:
> !http://i.imgur.com/O1aBUPR.png!
> These objects could be instanciated only once and stored as static class
> fields.
> {noformat}
> odata-core/src/main/java/org/apache/olingo/odata2/core/commons/XmlHelper.java
> 41: XMLInputFactory factory = XMLInputFactory.newInstance();
> odata-core/src/main/java/org/apache/olingo/odata2/core/debug/DebugInfoBody.java
> 120: Transformer transformer =
> TransformerFactory.newInstance().newTransformer();
> odata-core/src/main/java/org/apache/olingo/odata2/core/edm/provider/EdmServiceMetadataImplProv.java
> 75: XMLStreamWriter xmlStreamWriter =
> XMLOutputFactory.newInstance().createXMLStreamWriter(writer);
> odata-core/src/main/java/org/apache/olingo/odata2/core/ep/AtomEntityProvider.java
> 110: XMLStreamWriter writer =
> XMLOutputFactory.newInstance().createXMLStreamWriter(outStream,
> DEFAULT_CHARSET);
> 165: XMLStreamWriter writer =
> XMLOutputFactory.newInstance().createXMLStreamWriter(outStream,
> DEFAULT_CHARSET);
> 201: XMLStreamWriter writer =
> XMLOutputFactory.newInstance().createXMLStreamWriter(outStream,
> DEFAULT_CHARSET);
> 228: XMLStreamWriter writer =
> XMLOutputFactory.newInstance().createXMLStreamWriter(outStream,
> DEFAULT_CHARSET);
> 257: XMLStreamWriter writer =
> XMLOutputFactory.newInstance().createXMLStreamWriter(outStream,
> DEFAULT_CHARSET);
> 286: XMLStreamWriter writer =
> XMLOutputFactory.newInstance().createXMLStreamWriter(outStream,
> DEFAULT_CHARSET);
> 313: XMLStreamWriter writer =
> XMLOutputFactory.newInstance().createXMLStreamWriter(outStream,
> DEFAULT_CHARSET);
> odata-core/src/main/java/org/apache/olingo/odata2/core/ep/BasicEntityProvider.java
> 245: XMLStreamWriter xmlStreamWriter =
> XMLOutputFactory.newInstance().createXMLStreamWriter(writer);
> odata-core/src/main/java/org/apache/olingo/odata2/core/ep/producer/AtomServiceDocumentProducer.java
> 60: XMLStreamWriter xmlStreamWriter =
> XMLOutputFactory.newInstance().createXMLStreamWriter(writer);
> {noformat}
> Thanks,
> John.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)