Configure optimization > Settings > Runtime
These settings define how runtime-specific recommendations are applied to workloads
4 minute read
StormForge recommendations can optionally include the Java max heap size that the machine learning has determined to be optimal for each Java container in a workload.
When configured, Optimize Live automatically analyzes critical Java metrics—such as heap and non-heap usage, as well as garbage collection data—and provides tailored recommendations for heap size adjustments alongside its recommendations for the container’s requests and limits.
To create Java Heap size recommendations, the StormForge Agent must be configured to collect JMX metrics. Use the jvmWorkloadConfigs
Helm parameter to accomplish this.
Typically, JMX metrics are exposed by using either Prometheus Java Metrics (Java library) or the Prometheus JMX Exporter (Java agent). However, as long as the method you use exposes the metrics in OpenMetrics format, you can use the jvmWorkloadConfigs
Helm parameter described below.
To identify the Java pods to optimize, StormForge uses a label selector comprised of the following:
/metrics
)Prerequisites:
--reset-then-reuse parameter
)To enable the Agent to collect metrics and generate Java Heap size recommendations, use the jvmWorkloadConfigs
Helm parameter.
You can copy the following template into a file named, for example, jvm-config.yaml, and then update it to suit your needs:
---
jvmWorkloadConfigs:
- labelSelector: "example.com/jvm-runtime=true,example.com/environment in (dev, prod)"
metricsPort:
scheme: "" # Optional string. Scheme port uses. Default is "http"
matchNumber: 0 # Optional number. Matches port number to scrape metrics from
matchName: "" # Optional string. Matches port name to scrape metrics from
metricsPath: "" # Default is "/metrics"
Run helm upgrade
to apply the setting:
helm upgrade stormforge-agent oci://registry.stormforge.io/library/stormforge-agent \
-n stormforge-system \
--reset-then-reuse-values \
-f jvm-config.yaml
This example assumes that your Java pods are:
example.com/jvm-runtime: "true"
web
to the /metrics
URL pathThe jvmWorkloadConfigs
parameter in your jvm-config.yaml
file would look like this:
# Helm values to enable StormForge Java Heap Size recommendations (beta)
jvmWorkloadConfigs:
- labelSelector: "example.com/jvm-runtime=true"
metricsPort:
matchName: "web"
metricsPath: "/jvm-metrics"
Optimize Live can apply heap size recommendations either by:
-XX:MaxRamPercentage
If the JVM MaxRamPercentage setting used by the app is taken as a constant, changing the memory limit will effectively change the max heap size too.
Configure cluster-defaults according to this example.
live.stormforge.io/containers.java.max-heap.patch-path: "-" # Set heap using memory limit
live.stormforge.io/containers.memory.optimization-policy: runtime:java=RequestsAndLimits
StormForge will calculate a recommended value for max heap. Rather than including the max heap value directly in the patch, the container’s memory limit will be set such that given the observed MaxRamPercentage, the desired max heap will be achieved.
In this case, no additional knowledge about the app’s configuration is needed to automatically manage the heap size.
While it is not strictly necessary to change the memory optimization policy, it is recommended to use RequestsAndLimits for memory when setting heap size via memory limits. Other memory optimization policies may have constraints that prevent Optimize Live from being able to fully implement the desired heap size using this method.
Configure cluster-defaults according to this example.
live.stormforge.io/containers.java.max-heap.patch-path: '{{ .EnvVarPath "STORMFORGE_JAVA_ARGS" }}'
live.stormforge.io/containers.java.max-heap.patch-format: '{{- jvmOption "-XX:MaxHeapSize" .Value }}'
If you do nothing more, StormForge will include the recommended max heap value in a patch thusly:
spec:
containers:
- name: my-jvm-container
env:
- name: STORMFORGE_JAVA_ARGS
value: -XX:MaxHeapSize=741m
Note that however you configure this environment variable, you must ensure that your application is configured to use it in order to ensure the value is actually consumed and takes effect.
When -
is configured as the Java max heap patch-path, this changes StormForge’s default calculation for the base (pre-policy and pre-constraints) recommended memory limit.
Normally, StormForge calculates a base recommended memory limit based on the configured Limit-Request Ratio (LRR).
limit = recommended-request ⨉ limit-request-ratio
For Java containers that have their Java max-heap patch-path set to -
, StormForge will change its base memory limit calculation to be:
limit = recommended-max-heap ÷ java-max-ram-percentage
All other characteristics and constraints of the selected memory optimization policy will still apply, including minimum and maximum bounds. This may mean that implementing the complete Java max heap recommendation is not possible, if the constraints or the optimization policy prevent setting the memory limit to exactly the desired value.
For the RequestsRaiseLimitsIfNeeded policy in particular, note that StormForge will still never lower memory limits for Java containers.
These settings define how runtime-specific recommendations are applied to workloads