-
Notifications
You must be signed in to change notification settings - Fork 282
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[BUG] DLS Performance with 2.16 #4670
Comments
@pmarjou22 Thanks for filing the issue. The profiler shows both Base64CustomHelper & Base64JDKHelper in hot spot. This could be due to call from SecurityInterceptor to ensureJDKSerialized here ensureJDKSerialized- https://github.com/opensearch-project/security/blob/main/src/main/java/org/opensearch/security/support/Base64Helper.java#L61-L65 However, this is not a change in 2.16 and present since 2.11. @pmarjou22 - can you share the complete stacktrace which will help confirm the above? Also, have you tried any other version < 2.16 with the same test? Note: |
The 2_16 non admin JProfiler file |
[Triage] @pmarjou22 Thank you for filing this issue. I'm surprised to see references to Base64CustomHelper on 2.16 since the custom serialization logic was removed in 2.14. Marking this issue as triaged. |
Hello @cwperks, do you have a PR or commit id for this removal you are talking about? I still see Base64CustomHelper in 2.16 |
Hi I've analyzed the 2_16 non admin JProfiler file @pmarjou22 provided. In the case of an opensearch cluster only composed with 2.16 nodes, I noticed some serializations are made with custom serializer. See : security/src/main/java/org/opensearch/security/configuration/DlsFlsValveImpl.java Line 470 in e36b800
as the default serializer is the custom one :
then a lot of time is spent to deserialize (with custom deserializer) then re-serialize with jdk, in
I performed some tests to complete what @pmarjou22 did :
This is the result made with jmeter : Here is the JProfiler of the last run (jdk only) : The changes I made are concentrated in Base64Helper :
I precise, in production we never mix different versions of opensearch in our cluster (we only do cold upgrade, never rolling upgrade). Do you have any feedback about this? |
Thanks a lot @acidul for the analysis. @peternied, is ensureJDKSerialized feature a mandatory check for security ? The serialization + deserialization that are done seems to be realy costly for non admin users having roles with DLS |
@pmarjou22 Its necessary in mixed clusters where some nodes use custom serialization and others use jdk serialization, but not in homogenous clusters (all nodes of the same version). This issue is actively being looked into and is related to this issue as well: #4494 |
What is the bug?
DLS security filter has a huge impact on performance. I open this ticket following @peternied advice on issue #3776
How can one reproduce the bug?
Launch a plain vanilla opensearch docker
create a role with dls filter :
{"bool":{"filter":[{"match_all":{}},{"bool":{"should":[{"match_phrase":{"currency":"EUR"}},{"match_phrase":{"currency":"molestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestiemolestie"}}],"minimum_should_match":1}}]}}
Iterate search posts in JMeter with a user non admistrator member of the role with a DLS filter. RandomVar is a random string preventing caching.
POST path /sample_data_ecommerce/_search?request_cache=false
POST body
{"size":500,"query":{"bool":{"filter":[{"bool":{"should":[{"match_phrase":{"currency":"EUR"}},{"match_phrase":{"currency":"${randomVar}"}},{"match_phrase":{"currency":"CAD"}},{"match_phrase":{"currency":"POR"}},{"match_phrase":{"currency":"REE"}},{"match_phrase":{"currency":"DSS"}},{"match_phrase":{"currency":"FDF"}},{"match_phrase":{"currency":"KJK"}},{"match_phrase":{"currency":"NBV"}},{"match_phrase":{"currency":"AZE"}},{"match_phrase":{"currency":"WXW"}},{"match_phrase":{"currency":"JDS"}},{"match_phrase":{"currency":"MLA"}},{"match_phrase":{"currency":"TRE"}}],"minimum_should_match":1}}],"must_not":[{"match_phrase":{"customer_full_name":"Frances Davidson"}},{"match_phrase":{"customer_first_name":"Frances"}},{"match_phrase":{"user":"elyssa"}}]}}}
Using 100 indexes (sample ecommerce clones with 2K documents) , we confirmed with JMeter the same behavior that explained in this bug
Version | Admin Rights (Call / Sec) | Limited Rights via DLS (Call / Sec)
2.10 | 33.2 | 21.7
2.13 | 32.6 | 10.2
2.14 | 46.65 | 3.3
2.15 | 45 | 3.1
2.16 | 36.2 | 3.2
What is the expected behavior?
A 30% overhead vs non filtered DLS like in 2.10 opensearch
What is your host/environment?
Do you have any screenshots?
I'm a first time user of jprofiler
CPU Hot Spot of non admin user
Hot Spot Comparison admin / non admin user
Admin Memory
Non Admin Memory
The text was updated successfully, but these errors were encountered: