opensearch-project / performance-analyzer

📈 Get detailed performance metrics from your cluster independently of the Java Virtual Machine (JVM)
https://opensearch.org/docs/latest/monitoring-plugins/pa/index/
Apache License 2.0
36 stars 66 forks source link

[BUG] PerformanceAnalyzerTransportChannel does not delegate to original TransportChannel that it wraps #606

Open cwperks opened 10 months ago

cwperks commented 10 months ago

When receiving a transport request, the security plugin relies on getting the version of the node that transmitted the request by calling on channel.getVersion(). When the original TransportChannel is wrapped by PerformanceAnalyzerTransportChannel, there is an issue where the version returned by channel.getVersion() is not accurate and instead gives the version of the node that received the transport request. In a homogenous cluster, that is not an issue, but it is an issue during rolling upgrades when a cluster is mixed.

See more details in the security repo here: https://github.com/opensearch-project/security/issues/3771

The problem is that PA instantiates a PerformanceAnalyzerTransportChannel w/o any args and then sets the original channel in a separate set call. Since PerformanceAnalyzerTransportRequestHandler does not override TransportChannel.getVersion() and delegate the call to the wrapped original channel, it will instead use the default implementation of TransportChannel.getVersion and return Version.CURRENT of the receiving node.

dblock commented 3 months ago

[Triage -- attendees 1, 2, 3, 4, 5, 6, 7]

Looks like a valid issue.