Memory optimization
No edit summary
(Automatically adding template at the end of the page.)
 
(12 intermediate revisions by 4 users not shown)
Line 1: Line 1:
Memory optimization in software refers to the process of reducing the memory footprint or memory usage of a program or application. It involves various techniques and strategies to make the most efficient use of available memory resources, resulting in improved performance, reduced memory consumption, and enhanced overall system efficiency.
=== General notes ===
Turnkey memory optimization that is built-in and does not need any configuration:
* Large blobs in a model are held in a shared location for all clients.
* Pruning (deallocation) of unused data structures periodically, usually every few minutes, even in views and in the EcoSpaces of active users.
* Removing ViewModels that have not been used for a few minutes.
* Removal of subscriptions and change publishers within EcoSpaces every few minutes.


Here are some common memory optimization techniques:
Using the ServerInfo page, you can temporarily tweak times for pruning stale apps and the intervals when the server does pruning. These settings are available to make it easier for you to tweak other settings without having to wait very long periods to see the effect.
# '''Data Structure Selection:''' Choosing the appropriate data structures can significantly impact memory usage. For example, using linked lists instead of arrays can save memory if the data size is dynamic. Similarly, using bit-level operations instead of boolean flags can reduce memory overhead.
# '''Data Compression:''' Compressing data can help reduce memory consumption. Techniques like run-length encoding, Huffman coding, or Lempel-Ziv-Welch (LZW) compression can be employed to compress data structures, files, or network payloads.
# '''Memory Pooling:''' Rather than allocating and deallocating memory for each object individually, memory pooling involves preallocating a fixed-sized pool of memory and reusing it for different objects. This reduces the overhead of memory management operations and improves memory allocation performance.
# '''Lazy Loading:''' Instead of loading all data into memory at once, lazy loading involves loading data on-demand or when it is actually required. This approach helps conserve memory by loading only the necessary portions of data, especially for large datasets or resources.
# '''Caching:''' Caching involves storing frequently accessed data in a temporary storage space, such as RAM, to improve access speed and reduce the need to fetch data from slower sources like disk or network. Caching can be used for various purposes, such as database query results, web page content, or computed values.
# '''Garbage Collection:''' In languages with automatic memory management (like Java or C#), garbage collection is responsible for reclaiming memory that is no longer in use. Optimizing garbage collection algorithms and settings can reduce memory fragmentation and improve the efficiency of memory reclamation.
# '''Memory Leak Detection:''' Identifying and fixing memory leaks is crucial for memory optimization. A memory leak occurs when memory is allocated but not properly deallocated, leading to a gradual increase in memory usage over time. Proper memory leak detection and fixing such issues prevent excessive memory consumption.
# '''Minimizing Redundancy:''' Eliminating redundant data or redundant memory allocations can significantly reduce memory usage. This can involve techniques like sharing immutable data across multiple instances or avoiding unnecessary duplication of large data structures.
# '''Profile-based Optimization:''' Profiling tools help identify memory usage patterns and hotspots in a program. By analyzing the profiling data, developers can pinpoint memory-intensive areas and apply targeted optimizations to reduce memory consumption.


Memory optimization is crucial in resource-constrained environments, such as embedded systems, mobile devices, or server environments where scalability and performance are key. By employing these techniques, developers can create more efficient and responsive software while maximizing the utilization of available memory resources.
=== .Net optimization settings for .Net Framework <4.8.1, not .Net core on IIS ===
When a .net application doesn't use objects anymore, they are garbage collected. The Garbage Collector (GC) can do its job in many ways.
 
By default, an MDriven Server uses the "Server" GC mode with the "Interactive" setting. This is to make the Garbage Collector run in the background and in a way that should minimize user "hick-ups", i.e. short delays for the user.
 
There's always a balance between user experience, memory use, and CPU use to consider.
 
* Tuning GC for high-density Web hosting: GC can impact a site’s memory consumption, but it can be tuned to enable better performance. You can tune or configure GC for better CPU performance (slow down the frequency of collections) or lower memory consumption (that is, more frequent collections to free up memory sooner).  
<performanceScenario value="HighDensityWebHosting"/>
* Tuning only when memory usage on server low memory conditions, use '''gcTrimCommitOnLowMemory''' like this:
<gcTrimCommitOnLowMemory enabled="true"/>
In both these settings, you add the settings to the '''runtime''' section of the '''aspnet.config''' file in the '''C:\Windows\Microsoft.NET\Framework64\v4.0.30319''' folder to achieve smaller memory consumption (working set) per site. [[File:Aspnet.config file example.png|none|thumb|627x627px]]
 
'''In an installation with more than one TK or MDS instance running on a Windows machine, we recommend both settings to make them run much better together, like this:'''


See also: [[Turnkey Client Timeout]]
See also: [[Turnkey Client Timeout]]
More reading:
https://learn.microsoft.com/en-us/archive/msdn-magazine/2012/april/clr-an-overview-of-performance-improvements-in-net-4-5
https://learn.microsoft.com/en-us/dotnet/standard/garbage-collection/optimization-for-shared-web-hosting
==== .net Core: ====
https://learn.microsoft.com/en-us/dotnet/core/runtime-config/garbage-collector#workstation-vs-server
[[Category:MDriven Turnkey]]
{{Edited|July|12|2024}}

Latest revision as of 15:37, 10 February 2024

General notes

Turnkey memory optimization that is built-in and does not need any configuration:

  • Large blobs in a model are held in a shared location for all clients.
  • Pruning (deallocation) of unused data structures periodically, usually every few minutes, even in views and in the EcoSpaces of active users.
  • Removing ViewModels that have not been used for a few minutes.
  • Removal of subscriptions and change publishers within EcoSpaces every few minutes.

Using the ServerInfo page, you can temporarily tweak times for pruning stale apps and the intervals when the server does pruning. These settings are available to make it easier for you to tweak other settings without having to wait very long periods to see the effect.

.Net optimization settings for .Net Framework <4.8.1, not .Net core on IIS

When a .net application doesn't use objects anymore, they are garbage collected. The Garbage Collector (GC) can do its job in many ways.

By default, an MDriven Server uses the "Server" GC mode with the "Interactive" setting. This is to make the Garbage Collector run in the background and in a way that should minimize user "hick-ups", i.e. short delays for the user.

There's always a balance between user experience, memory use, and CPU use to consider.

  • Tuning GC for high-density Web hosting: GC can impact a site’s memory consumption, but it can be tuned to enable better performance. You can tune or configure GC for better CPU performance (slow down the frequency of collections) or lower memory consumption (that is, more frequent collections to free up memory sooner).
<performanceScenario value="HighDensityWebHosting"/>
  • Tuning only when memory usage on server low memory conditions, use gcTrimCommitOnLowMemory like this:
<gcTrimCommitOnLowMemory enabled="true"/>

In both these settings, you add the settings to the runtime section of the aspnet.config file in the C:\Windows\Microsoft.NET\Framework64\v4.0.30319 folder to achieve smaller memory consumption (working set) per site.

Aspnet.config file example.png

In an installation with more than one TK or MDS instance running on a Windows machine, we recommend both settings to make them run much better together, like this:

See also: Turnkey Client Timeout

More reading:

https://learn.microsoft.com/en-us/archive/msdn-magazine/2012/april/clr-an-overview-of-performance-improvements-in-net-4-5

https://learn.microsoft.com/en-us/dotnet/standard/garbage-collection/optimization-for-shared-web-hosting

.net Core:

https://learn.microsoft.com/en-us/dotnet/core/runtime-config/garbage-collector#workstation-vs-server

This page was edited more than 11 months ago on 02/10/2024. What links here