You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@camel.apache.org by "Claus Ibsen (Jira)" <ji...@apache.org> on 2021/02/25 06:22:00 UTC

[jira] [Resolved] (CAMEL-16213) camel-core - Exchange pooling

     [ https://issues.apache.org/jira/browse/CAMEL-16213?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Claus Ibsen resolved CAMEL-16213.
---------------------------------
    Resolution: Fixed

> camel-core - Exchange pooling
> -----------------------------
>
>                 Key: CAMEL-16213
>                 URL: https://issues.apache.org/jira/browse/CAMEL-16213
>             Project: Camel
>          Issue Type: New Feature
>          Components: came-core
>            Reporter: Luca Burgazzoli
>            Assignee: Claus Ibsen
>            Priority: Major
>             Fix For: 3.9.0
>
>
> By default a brand new exchange is created for each message received by a component and that's usually fine but for very simple routes, like those created by the camel-kafka-connector or the Kantive Sources in camel-k it may be useful to have an option to create pools of reusable exchanges as:
> - exchanges are short living objects and routes are simple 
> - exchanges are heavy (multiple maps for properties and headers)
> - camel-kafka-connector and knative sources are likely to receive the same messages type, with the same set of headers so the maps allocated by the exchange can safely be recycled to reduce allocations and resizing
> In addition to the reason above, we can leverages exchange pooling to:
> - implement back pressure driven by the resource constraints to be sure we don't exceed resources consumption and we don't degrade the the service (i.e. long GC pause) 
> - have a way to create tailored exchanges, i.e. by providing an exchange that does not have in/out but just in  
> An example of fast and efficient ASL2 licensed object pooling: https://github.com/chrisvest/stormpot



--
This message was sent by Atlassian Jira
(v8.3.4#803005)