diff options
author | Maoni Stephens <Maoni0@users.noreply.github.com> | 2019-01-29 13:09:32 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-01-29 13:09:32 -0800 |
commit | ed52a006c01a582d4d34add40c318d6f324b99ba (patch) | |
tree | 206844e7a9ececb7960a9cdd47e899718269644a /src/gc/env | |
parent | 930abba4060fb528db2bb9835a1bc5a6e684bfec (diff) | |
download | coreclr-ed52a006c01a582d4d34add40c318d6f324b99ba.tar.gz coreclr-ed52a006c01a582d4d34add40c318d6f324b99ba.tar.bz2 coreclr-ed52a006c01a582d4d34add40c318d6f324b99ba.zip |
To support container scenario, 2 HardLimit configs are added - (#22180)
GCHeapHardLimit - specifies a hard limit for the GC heap
GCHeapHardLimitPercent - specifies a percentage of the physical memory this process is allowed to use
If both are specified, GCHeapHardLimit is checked first and only when it's not specified
would we check GCHeapHardLimitPercent.
If neither is specified but the process is running inside a container with a memory
limit specified, we will take this as the hard limit:
max (20mb, 75% of the memory limit on the container)
If one of the HardLimit configs is specified, and the process is running inside a container
with a memory limit, the GC heap usage will not exceed the HardLimit but the total memory
is still the memory limit on the container so when we calculate the memory load it's based
off the container memory limit.
An example,
process is running inside a container with 200mb limit
user also specified GCHeapHardLimit as 100mb.
if 50mb out of the 100mb is used for GC, and 100mb is used for other things, the memory load
is (50 + 100)/200 = 75%.
Some notes on these configs -
+ The limit is the commit size.
+ This is only supported on 64-bit.
+ For Server GC the minimum *reserved* segment size is 16mb per heap, this is to avoid the
scenario where the hard limit is small but the process can use many procs and we end up
with tiny segments which doesn't make sense. We then keep track of the committed on the segments
so the total does not exceed the hard limit.
Diffstat (limited to 'src/gc/env')
-rw-r--r-- | src/gc/env/gcenv.os.h | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/src/gc/env/gcenv.os.h b/src/gc/env/gcenv.os.h index b3797c3a43..3224f71d9d 100644 --- a/src/gc/env/gcenv.os.h +++ b/src/gc/env/gcenv.os.h @@ -347,10 +347,14 @@ public: // Get the physical memory that this process can use. // Return: // non zero if it has succeeded, 0 if it has failed + // *is_restricted is set to true if asked and running in restricted. // Remarks: // If a process runs with a restricted memory limit, it returns the limit. If there's no limit // specified, it returns amount of actual physical memory. - static uint64_t GetPhysicalMemoryLimit(); + // + // PERF TODO: Requires more work to not treat the restricted case to be special. + // To be removed before 3.0 ships. + static uint64_t GetPhysicalMemoryLimit(bool* is_restricted=NULL); // Get memory status // Parameters: |