JVM memory for Magnolia on PaaS

Magnolia is a Java application running in a Java Virtual Machine (JVM) that consumes memory. You control the memory used by both the JVM and the Magnolia pod through the values you specify when deploying Magnolia with its Helm chart.

The JVM running Magnolia uses:

  • heap memory that the JVM periodically reclaims (garbage collection)

  • off heap memory needed to run the JVM for garbage collection, class storage, threading and other usage.

Too little memory?
  • Too little heap memory can cause Magnolia to run more slowly because the JVM spends too much time in garbage collection or cause Magnolia to stop (and be restarted automatically) because it has insufficient memory.

    For more on this, see Pods restarting.

  • Too little off heap memory can cause unexpected restarts of Magnolia due to "out of memory kills" by your Kubernetes cluster because the Magnolia pod has violated its memory limit.

How do I control the memory?

You control the memory used by the Magnolia instances and the JVM with the following Helm chart values:

  • The memory limits you set for the Magnolia pods (the magnoliaAuthor.resources.limits.memory and magnoliaPublic.resources.limits.memory values)

  • The maximum memory used for the JVM heap (the magnoliaAuthor.setenv.memory.maxPercentage and magnoliaPublic.setenv.memory.maxPercentage values)

The memory limit determines the overall memory (heap and off heap) available to the JVM. The maxPercentage values determines the maximum size of the JVM heap and how much of the pod memory is left over for off heap memory.

Best Practice

Allow several gigabytes for off heap memory use by the Magnolia JVM.

Magnolia can use off heap memory for:

  • Imaging operations (resizing, cropping, other image manipulation)

  • Compressing or decompressing files

  • Publishing, especially when publishing large digital assets or doing recursive publications

The default values for magnoliaAuthor.setenv.memory.maxPercentage and magnoliaPublic.setenv.memory.maxPercentage is 60 (percent) which should cover typical Magnolia projects given a large enough memory limit for the Magnolia pod. However, it can be difficult to predict how much off heap memory may be needed by Magnolia.

If Magnolia is "out of memory killed" by Kubernetes, you can either:

  • increase the memory limit for the Magnolia pod increasing both the heap and off heap memory available to Magnolia

  • reduce the maxPercentage value decreasing the heap memory and increasing off heap memory

Feedback

PaaS

×

Location

This widget lets you know where you are on the docs site.

You are currently perusing through the Magnolia PaaS docs.

Main doc sections

DX Core Headless PaaS Legacy Cloud Incubator modules