Med: daemons: Don't add repeated I_PE_CALC messages to the fsa queue. #3977
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Let's say you have a two node cluster, node1 and node2. For purposes of testing, it's easiest if you use fence_dummy instead of a real fencing agent as this will fake fencing happening but without rebooting the node so you can see all the log files.
Assume the DC is node1. Now do the following on node2:
It will take a long time to create that many resources. After node1 comes out of standby, it'll take a minute or two but eventually you'll see that node1 was fenced. On node1, you'll see a lot of transition abort messages happen. Each of these transition aborts causes an I_PE_CALC message to be generated and added to the fsa queue. In my testing, I've seen the queue grow to ~ 600 messages, all of which are exactly the same thing.
These messages are fed into controld's glib event loop at G_PRIORITY_HIGH, while the presence of regular IPC messages trigger at G_PRIORITY_DEFAULT. Thus, the fsa messages take priority. It takes a while for controld to process all these high priority messages, during which time it is unable to read anything out of its IPC backlog.
based continues to attempt to send IPC events to controld but is unable to do so, so the backlog continues to grow. Eventually, the backlog reaches that 500 message threshold without anything having been read by controld, which triggers the eviction process.
There doesn't seem to be any reason for all these I_PE_CALC messages to be generated. They're all exactly the same, they don't appear to be tagged with any unique data tying them to a specific query, and their presence just slows everything down.
Thus, the fix here is very simple: if the latest message in the queue is an I_PE_CALC message, just don't add another one. We could also make sure there's only ever one I_PE_CALC message in the queue, but there could potentially be valid reasons for there to be multiple interleaved with other message types. I am erring on the side of caution with this minimal fix.
Related: RHEL-76276