Configure Runtime Java options
Semarchy xDI Runtime starts by running a Java command that includes command-line options. You can set your own Java options for xDI Runtime in two ways:
-
Add Java options to environment variables that xDI recognizes.
-
Add Java options to the
initvariables
startup script.
Both methods pass arguments to Java at startup. You must use command-line syntax such as -D<property>=<value>
or other valid arguments. Separate multiple arguments with spaces, and use quotes to delimit values that contain spaces.
The first method is the most reliable and compatible, and you should use it where possible.
Make sure your runtime is not running before changing the configuration or environment. |
How to set Java options
With environment variables
The environment variables that xDI Runtime looks for work in different situations, and you can set one or both as needed:
-
XDI_COMMAND_OPTS
: Applies to the Runtimestartcommand.bat
andstartcommand.sh
scripts. -
XDI_RUNTIME_OPTS
: Applies to all other Runtime runnable scripts.
Both environment variables take space-separated Java options in command-line format.
With the initvariables script
The initvariables
script takes Java options that apply to all xDI Runtime actions.
-
In the runtime install directory, find the
initvariables.bat
(Windows) orinitvariables.sh
(Linux, macOS) file. -
Open the file for editing.
-
Go to the line that starts with
XDI_RUNTIME_VM_PROPERTIES
orset XDI_RUNTIME_VM_PROPERTIES
. -
Add your Java arguments alongside the existing commands, in command-line format.
Useful Java options for Runtime
This section lists Java settings or properties that are of particular use to xDI Runtime.
Adjust the runtime memory capacity
By default, Runtime allows the Java Virtual Machine to manage memory automatically. The default should work in most cases, but you can use -X
Java arguments to set Runtime memory usage.
To change Runtime memory usage, set these in the initvariables
script or in environment variables.
# Minimum heap size
-Xms512m
# Maximum heap size
-Xmx2048m
# Stack size
-Xss4m
Set the runtime shutdown delay
xDI Runtime understands a custom Java property that controls its shutdown delay.
To configure the runtime’s shutdown delay, use the com.semarchy.xdi.graceful-shutdown-delay
property, and set its value to an integer followed by a time designator.
-Dcom.semarchy.xdi.graceful-shutdown-delay=30s
Adjust limits for XML and XPath processing
The Java Virtual Machine sets limits for processing XML and XPath data. If you work with large datasets, you may get an error such as org.xml.sax.SAXParseException
, warning about exceeding processing limits.
To work around these limits, you must set Java properties to modify the limits. These properties are set with the -D
argument, and you can find the full list on the Java API for XML Processing (JAXP) Security Guide.
Manage runtime monitoring with Java Management Extensions
Java Management Extensions (JMX) is a technology for managing and monitoring Java applications. It allows you to follow memory or class usage with utilities like jmap
or external tools such as Visual VM. Java enables JMX features by default, but only on the local machine unless explicitly set otherwise. In this way, you can make use of JMX to monitor the xDI Runtime locally.
For more information about JMX, see the Oracle documentation.
If you want to prevent tools from monitoring the xDI Runtime, you can disable JMX in one of two ways.
Customize true/false JDBC Boolean values
When using a JDBC driver, Runtime returns and displays Booleans as 1
for true and 0
for false. If you prefer to use other strings to represent Booleans, such as true
or false
, two Java parameters control this setting for JDBC drivers. Set the parameters in the initvariables
script or in environment variables.
# Text for true values
-Dcom.semarchy.xdi.jdbc-conversion.boolean.truevalue=<your-value-here>
# Text for false values
-Dcom.semarchy.xdi.jdbc-conversion.boolean.falsevalue=<your-value-here>
The following example sets the text to true
and false
respectively.
-Dcom.semarchy.xdi.jdbc-conversion.boolean.truevalue=true
-Dcom.semarchy.xdi.jdbc-conversion.boolean.falsevalue=false