Details
-
Bug
-
Status: Resolved
-
Major
-
Resolution: Fixed
-
3.16.0
-
None
-
Unknown
Description
Discussion thread:
Details:
While using camel-onlingo2 to read from ODataV2 endpoint in Java, the "I/O Dispatcher" threads are left running even after closing the camel context.
Camel version: 3.15.0/3.16.0
With camel version 2.24.1, the issue was not reproducible.
Attaching a demo project to show the issue. Run ODataReaderTest.java to reproduce the issue
-> With 3.15.0/3.16.0 version, there are 12 I/O Dispatcher threads which keeps running after every execution. So, every time the odata call is made the number of left over threads are piling up. This is eating up the resources on the server.
-> If camel version is changed to 2.24.1 ( build.gradle file, change value of camelVersion ), then with camel context stop, all the I/O Dispatcher threads are also closed. The same test case (ODataReaderTest) will pass with 2.24.1 version.
Analysis:
The below code is getting called twice for every execution and because of the IF condition multiple instances of Olingo2AppWrapper (apiProxy) are getting created.
And each of this instance creates 12 I/O Dispatcher threads. When camel context is closed only one of the instance of apiProxy ( the one which is created last) is closed, which leaves threads created by first instance as it is in RUNNING state.
With older version (2.24.1), only one instance of Olingo2AppWrapper (apiProxy) was getting created.
There is configuration variable defined in newer version which didn't exist in older version. This seems to be impacting the IF conditions and leading to multiple apiProxy instances.
Olingo2Configuration configuration;
Attachments
Attachments
Issue Links
- links to