-
Notifications
You must be signed in to change notification settings - Fork 593
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
Reader / Writer improvements #857
Conversation
MethodArgumentReader/Writer
ContentHeaderPropertyReader/Writer
|
The property case doesn't improve due to the small amount of "non bit" writes. But at least it isn't worse. At the moment most of the time is spent in the encoding of strings / special handling due to the required array in the Full Framework and .Net Standard 2.0. |
The full span does also improve the performance quite a bit for these paths (and simplify the code) but I can't share numbers as I did only a small test. And before doing all the work, I'd like to know whether this is something that would be accepted. |
@bollhals what does "going full span" mean for the supported .NET version matrix? |
We always use spans for any type -> byte conversions (e.g. NetworkOrderDeserializer / NetworkOrderSerializer) except for strings, due to the fact that there is no framework encoding method for spans below .Net Standard 2.1 (Here's the one for NS2.1). By "going full span" I mean that we'd not be using Memory anymore in the conversion methods. But this is only possible if we can use Spans for strings. One possibility to acheive this for < NS2.1 is to use code like this
but it requires the "unsafe" switch enabled. Why would we want to do this? |
Thanks for the detailed explanation. My question was about the .NET [Framework | Core] versions we would have to require if we adopt .NET Standard 2.1. Per this .NET standard implementation matrix, there is no .NET Framework version implementing .NET Standard 2.1, and the minimum .NET Core version supporting it is 3.0. .NET Standard 2.1 announcement post suggests that .NET Framework may never support this version. If that's the case, this is likely a no-go for most libraries to require it at this time. |
From the above post:
|
You're correct about the frameworks. NS2.1 would target only .Net Core 3.0+, while NS2.0 supports (still officially supported) .Net 4.61 & .Net Core 2.1. I was under the impression that for 7.0 the support for .NET Framework might be dropped?
Also the posted workaround also works for NS2.0 (but requires the unsafe switch), so this would still be possible, but whether or not to use the unsafe switch, is something that's needs to be decided upon. |
I have made some tests locally with the described workaround for the current supported platforms. |
Fair enough, if the community believes such a release would have enough users to justify, we can consider it. |
Considering that .NET Framework will probably not see any updates except for security updates, and that MS is pushing full force for .NET 5 as it's next release, my personal opinion is that 7.0 should target .NET Standard 2.1, and 6.X should be the last .NET Framework supported release. This is of course always a debatable thing, but given that for example some C# 8.0 language features can only be used in .NET Core it's obvious that .NET Framework is just on life support until it's support lifetime runs out, it seems like a good cutoff point to leave behind legacy code and move the codebase forward. At that point it'd make sense to create a separate 6.X branch for reliability/security updates and possibly minor features. My full-async PR (which I'm hoping to submit for your review in the next few days) targets only .NET Standard 2.1 and the latest .NET Core LTS version (3.1) is already .NET Standard 2.1 ready. |
Also, regarding strings, there is work ongoing in the .NET Core runtime to make a native UTF8 String type which is ideal for a library like this. I don't know exactly what the progress is there or if it'll make it for .NET 5. Perhaps @GrabYourPitchforks has an update on the progress there. |
Updated benchmarks:
|
projects/RabbitMQ.Client/client/impl/ContentHeaderPropertyWriter.cs
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is some extra whitespace that needs to be removed. Also, is this PR 100% complete? I remember reading an earlier comment that suggested this is only part of the work, but I can't seem to find it 🤔
The "only part of the work"-thing was the part about whether or not use the unsafe switch and thus use the span everywhere in the wireformatting. I've done that in d0d3032. So this PR is now complete and ready for review. |
what is the benefit of targeting .NET Standard 2.1? As it stands my understanding is that .NET Standard 2.1 is basically more or less a dead end. With the introduction of .NET 5 the standards have been merged into .NET 5 TFM. But that being said .NET 5 will not even be the LTS version. Only .NET 6 will be the LTS version. So from a consumer perspective nobody but bleeding edge contributors really care in what language version the rabbitmq client is written or do they? I would guess from a Pivotal / VMWare perspective given the broad adoption of the rabbitmq client having a broader set of compatibility makes more sense instead of too early corner the client in "just because performance" (of course this is drastically and potentially unfairly simplified for the sake of my argument ;) ). Yes .NET 4.8 is basically the last version and only .NET 4.7.2 and higher properly supports .NET Standard 2.0. Even though .NET Standard 2.0 is a little bit of a disaster and the System packages used can cause headaches and don't offer the true perf one would expect (and sometimes even cause binding redirect issues) wouldn't it from an adoption perspective as well as long tail perspective make sense to stay a bit longer on the .NET Standard 2.0 train (with or without dual targeting to .NET Framework)? |
I've created an issue #867 to separate the discussion about the supported frameworks and the content of this PR. |
squashed and rebased against master |
Proposed Changes
Simplified a few things around frames and reader / writer for MethodArgument & Properties. This results in a small gain on the hot paths and prepares the code for full "spanification" on the read / write actions. (See comment)
Types of Changes
Checklist
CONTRIBUTING.md
document