Skip to content

Commit

Permalink
Refine note on listener container setup with CachingConnectionFactory
Browse files Browse the repository at this point in the history
Closes gh-25503
  • Loading branch information
jhoeller committed Sep 2, 2023
1 parent 3e3f051 commit 61f89a1
Showing 1 changed file with 8 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -98,12 +98,14 @@
* number of 1 consumer, otherwise you'd receive the same message multiple times on
* the same node.
*
* <p><b>Note: Don't use Spring's {@link org.springframework.jms.connection.CachingConnectionFactory}
* in combination with dynamic scaling.</b> Ideally, don't use it with a message
* listener container at all, since it is generally preferable to let the
* listener container itself handle appropriate caching within its lifecycle.
* Also, stopping and restarting a listener container will only work with an
* independent, locally cached Connection - not with an externally cached one.
* <p><b>Note: You may use {@link org.springframework.jms.connection.CachingConnectionFactory}
* with a listener container but it comes with limitations.</b> It is generally preferable
* to let the listener container itself handle appropriate caching within its lifecycle.
* Also, stopping and restarting a listener container will only work with an independent,
* locally cached {@code Connection}, not with an externally cached one. Last but not least,
* with {@code CachingConnectionFactory}, dynamic scaling with custom provider hints such as
* {@link #setMaxMessagesPerTask "maxMessagesPerTask"} can result in JMS messages delivered
* to cached consumers even when they are no longer attached to the listener container.
*
* <p><b>It is strongly recommended to either set {@link #setSessionTransacted
* "sessionTransacted"} to "true" or specify an external {@link #setTransactionManager
Expand Down

0 comments on commit 61f89a1

Please sign in to comment.