Environment variables

The Orchestrator can read environment variables which alter the way it runs. These can be:

  • Orchestrator-specific environment variables (normally prefixed with MAVERICS_)
  • Arbitrary environment variables which can be referenced in the config file itself
⚠️
The environments variable file (maverics.env) is only supported on Linux. It is not currently supported on Windows. To install the orchestrator on Windows with environment variables, you must use the MSI installer.

Orchestrator Environment Variables

ℹ️
Environment variables in the maverics.env file must use the VARIABLE_NAME=VARIABLE_VALUE format. See our examples for more information.

The following environment variables are available for setting Orchestrator configuration:

Command line options for maverics will override environment variables, which in turn will override settings in the configuration file. The order of precedence is:

  1. command line options (e.g. -verbose for debug level logging)
  2. environment variables (e.g. MAVERICS_DEBUG_MODE=true)
  3. settings in the configuration file (e.g. logger.level: debug)

Additionally, the Windows installer of Maverics sets the a variable named MAVERICS_CONFIGURATION_TYPE, which indicates whether the configuration is a Maverics Cloud configuration, local file, or local bundle file. This variable is used by the orchestrator installer only, and is not used by the orchestrator itself.

Arbitrary Environment Variables

Maverics supports referencing environment variables in configuration files. This enables deployment specific variables to be set dynamically.

To express environment variables in config files, use the {{ env.VAR_NAME }} syntax. Note, the env. namespace prefix is required.

Examples

Setting environment variables on Linux

To set an environment variable after installing on linux, use the maverics.env file that is found in the /etc/maverics directory by default. Please note that the variables should be delimited by a newline and should use the VARIABLE_NAME=VARIABLE_VALUE format.

/etc/maverics/maverics.env

MAVERICS_HTTP_ADDRESS=":443"
MAVERICS_TLS_SERVER_CERT_FILE="/etc/maverics/example.com.crt"
MAVERICS_TLS_SERVER_KEY_FILE="/etc/maverics/example.com.key"

Setting environment variables on Windows

For standard environments variables (variables prefixed with MAVERICS) like log verbosity, the MSI should be used. To update existing settings, simply reinstall the MSI.

Setting environment variables on Containers

Similarly to Linux, a simple way to provide environment variables to the container is via an environment variable file. The variables should be delimited by a newline and should use the VARIABLE_NAME=VARIABLE_VALUE format. When starting the container, use the --env-file flag.

maverics.env

MAVERICS_DEBUG_MODE=true

Referencing custom environment variables

The following example represents a simple usage of how environment variables can be leveraged. The example assumes that AZURE_METADATA_URL, AZURE_ACS_URL, and AZURE_ENTITY_ID are set as environment variables on the host machine.

connectors:
  - name: azure
    type: azure
    authType: saml
    samlMetadataURL: '{{ env.AZURE_METADATA_URL }}'
    samlConsumerServiceURL: '{{ env.AZURE_ACS_URL }}'
    samlEntityID: '{{ env.AZURE_ENTITY_ID }}'