diff --git a/chaos-days/blog/2024-12-12-News-from-Camunda-Exporter-project/index.md b/chaos-days/blog/2024-12-12-News-from-Camunda-Exporter-project/index.md index 54ba73d62..18e3ec7fc 100644 --- a/chaos-days/blog/2024-12-12-News-from-Camunda-Exporter-project/index.md +++ b/chaos-days/blog/2024-12-12-News-from-Camunda-Exporter-project/index.md @@ -12,10 +12,10 @@ authors: zell # Chaos Day Summary -In this Chaos day we want to verify the current state of the exporter project, and run benchmarks with it. Comparing +In this Chaos day, we want to verify the current state of the exporter project and run benchmarks with it. Comparing with a previous version (v8.6.6) should give us a good hint on the current state and potential improvements. -**TL;DR;** The performance that the user sees data has been improved due to the architecture change, but there are still some bugs that we have to fix until the release. +**TL;DR;** The latency of user data availability has improved due to our architecture change, but we still need to fix some bugs before our planned release of the Camunda Exporter. This experiment allows us to detect three new bugs, fixing this should allow us to make the system more stable. @@ -23,14 +23,14 @@ with a previous version (v8.6.6) should give us a good hint on the current state ### Benchmarks -We have seen in previous experiments and benchmarks that the realistic benchmarks are not yet totally reliable, as they seem to overload at some-point the system. This can happen if there is a hiccup and jobs take longer to process. Jobs in the queue are getting delayed, and time out, they are sent out to different workers, but we will reach at some point again the jobs, and we will publish also for this job a message. This in general increases the load of the system as we have to timeout jobs, we have to handle additional message publish, etc. +We have seen in previous experiments and benchmarks that the realistic benchmarks are not yet totally reliable, as they seem to overload at some point the system. This can happen if there is a hiccup and jobs take longer to process. Jobs in the queue are getting delayed, and time out, they are sent out to different workers, but we will reach them at some point again the jobs, and we will publish also for this job a message. This in general increases the load of the system as we have to timeout jobs, we have to handle additional message publish, etc. -Additionally, message publish can be rejected, when this happens we wait for another timeout adding again load on the system, more and more retries happen etc. this breaks the benchmark performance. +Additionally, message publish can be rejected, when this happens we wait for another timeout adding again load on the system, more and more retries happen, etc. This breaks the benchmark performance. -To avoid this, we reduce the benchmark payload for now, which is in charge of creating multi instances and call activities etc. To be specific, the reduced the items from 50 to 5, -but scaled the starter to start more instances. With this payload we can scale more fine granular. Each instance can create 5 sub-instances, when creating three process instances we create effectively 15 instances/token. +To avoid this, we reduce the benchmark payload for now, which is in charge of creating multiple instances and call activities, etc. To be specific, they reduced the items from 50 to 5 +but scaled the starter to start more instances. With this payload, we can scale more fine granular. Each instance can create 5 sub-instances, when creating three process instances we create effectively 15 instances/token. -As this the benchmark runs quite stable, it allows us to better compare the latency between based and main. +As this benchmark runs quite stable, it allows us to better compare the latency between base and main. ### Details Experiment @@ -38,10 +38,10 @@ We will run two benchmarks one against 8.6.6, call based, and one against the cu ### Expected -When running the base and the main and comparing each other we expect that the general throughput, should be similar. -Furthermore, we expect that the latency until the user sees data (or data is written into ES and searchable) should be lowered on main than base. +When running the base and the main and comparing each other we expect that the general throughput should be similar. +Furthermore, we expect that the latency until the user sees data (or data is written into ES and searchable) should be lowered on the main branch rather than on the base. -Note: Right now we don't have a good metric to measure that data is available for the user, we plan to implement this in the starter benchmark application at some-point via querying the REST API. For now, we calculate different average latencies together, whereas we take as elasticsearch flush a constant of 2 seconds. +Note: Right now we don't have a good metric to measure that data is available for the user, we plan to implement this in the starter benchmark application at some point via querying the REST API. For now, we calculate different average latencies together, whereas we take as elastic search flush a constant of 2 seconds. We expect a reduction of latency as we reduce one additional hop/usage of ES as intermediate storage, before aggregation. @@ -70,7 +70,7 @@ The general throughput performance looks similar. The resource consumption looks #### Latency -This experiment targets to show difference in the data availability for the user. +This experiment aims to show the difference in the data availability for the user. In order to better visualize the dashboard has been adjusted for this experiment. @@ -92,22 +92,22 @@ We were able to show that the latency has been reduced under normal load. #### Found Bugs -Within the experiment we run into several other issues. Especially after running for a while, when pods got restarted and importer have been enabled, the Camunda Exporter broke. +Within the experiment, we run into several other issues. Especially after running for a while, when pods got restarted and importer have been enabled, the Camunda Exporter broke. ![exporting-fail](exporting-fail.png) -This caused to increase the latency. +This caused to increase in the latency. ![exporting-fail-latency](exporting-fail-latency.png) -The exporter was not able to detect correctly anymore that the importing was done, but was still flushing periodically (which is as well wrong) +The exporter was not able to detect correctly anymore that the importing was done but was still flushing periodically (which is as well wrong) -See related github issue(s) +See related GitHub issue(s) * [Importer(s) are not communicating import done correctly](https://github.com/camunda/camunda/issues/26046) * [Exporter flushes periodically even when importer not completed](https://github.com/camunda/camunda/issues/26047) -Furthermore, based on logs we saw that the treePath hasn't be published correctly in the Exporter. +Furthermore, based on logs we saw that the treePath hasn't been published correctly in the Exporter. - * [Camunda Exporter is not able to consume treePath](https://github.com/camunda/camunda/issues/26048) \ No newline at end of file + * [Camunda Exporter is not able to consume treePath](https://github.com/camunda/camunda/issues/26048)