Skip to content
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

v9 ideas #345

Open
valdisiljuconoks opened this issue Dec 5, 2024 · 3 comments
Open

v9 ideas #345

valdisiljuconoks opened this issue Dec 5, 2024 · 3 comments
Assignees
Milestone

Comments

@valdisiljuconoks
Copy link
Owner

valdisiljuconoks commented Dec 5, 2024

Echo from community:

  • Change TypeFactory to regular dependency injection. It seems to allocate too much memory.
  • Optimize ResourceKeyBuilder further.
  • Consider replacing the queries with regular service class methods. They are not particularly slow. But the creation of them seems slow.
  • Store the result of GetAllResources as a dictionary, so it is cached like that, as it is much faster to pull specific resources by name this way.
  • It could also be nice to look into the data layer, like test the performance of loading from SQL Server, and the caching of data.
  • enable + fix nullability
@stefanolsen
Copy link
Contributor

stefanolsen commented Jan 5, 2025

Regarding the data layer. I can see that we do a join between resource and translation, when reading all resources. So the cardinality is high.
Should we split the two table queries, using multiple result sets, and then merge the data on reading?

A small optimization could be overloads to LocalizationProvider methods, without the params array parameter. In cases where those are not needed, those would take a shortcut.

@valdisiljuconoks
Copy link
Owner Author

I cannot rely on having MRS enabled (which is also not recommended due to potential perf. penalty).

How much gain we are talking here? I've done sandbox now with 10k resources and 5 languages. Performance is not tragic there. Sync of resources initially on startup was problem. Got it down from ~40sec to ~2sec.

@stefanolsen
Copy link
Contributor

I haven't profiled the data layer, yet.

I might look into the runtime allocations first. As they can be a bigger issue on very high loads.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants