| This is documentation for Semarchy xDM 2023.4, which is no longer supported. For more information, see our Global Support and Maintenance Policy. | 
Startup configuration methods
This page describes the different startup configuration methods for Semarchy xDM.
The startup configuration consists of a set of configuration properties with their values. Property names are lowercase strings with dot delimiters, and begin with the xdm. prefix.
For example:
- 
xdm.config.fileconfigures the location of the default configuration file.
- 
xdm.secrets.internal.kms.currentconfigures the alias of the current key management service used to encrypt secrets.
There are three ways to set the configuration properties:
Configuration method priority
The value of each property is read in the following order:
- 
From the configuration file. 
- 
From the corresponding environment variable, overriding the configuration file value. 
- 
From the Java system property, overriding both the configuration file and environment variable values. 
For example, if a property is set in the configuration file and as a Java system property, then the Java system property is used.
| The different methods for the startup configuration are useful for each type of setup: 
 | 
Java system properties
With this method, configuration properties are set in the startup command of the Java virtual machine (JVM) running Semarchy xDM, using the following syntax:
-D<property.name>=<value>For example:
-Dxdm.secrets.internal.kms.current=awscorporateFor Tomcat, you can set such a property in the <tomcat>/bin/setenv.sh|bat file, as shown below:
CATALINA_OPTS="$CATALINA_OPTS -Dxdm.secrets.internal.kms.current=awscorporate"On Windows, you can alternatively use the Tomcat Configuration GUI tool to define these properties in the Java Options field of the Java tab.
| If the  | 
Environment variables
With this method, variables are set in the environment running the JVM.
The variable names are derived from the Java properties, converted to uppercase, with dots replaced by underscores. For example, the xdm.secrets.internal.kms.current property value is set in the XDM_SECRETS_INTERNAL_KMS_CURRENT environment variable.
The following examples illustrate how to set this configuration property in the environment.
# Set environment variable: Unix/Linux
export XDM_SECRETS_INTERNAL_KMS_CURRENT=awscorporate
# See the variable value
# echo $XDM_SECRETS_INTERNAL_KMS_CURRENTrem Set environment variable: Windows
set XDM_REPOSITORY_DRIVER=oracle.jdbc.OracleDriver
rem See the variable value
rem echo %XDM_REPOSITORY_DRIVER%When running Tomcat as a service on Windows, it is recommended to set the startup configuration using environment variables. You can achieve this either:
- 
From the Windows Control Panel. Environment variables set in the Control Panel must be set as system variables when Tomcat runs as a service. 
- 
By configuring the service using Tomcat tooling. Add an environment variable for Tomcat running as a service (Windows)tomcat9 //US//Tomcat9 ++Environment XDM_REPOSITORY_DRIVER=oracle.jdbc.OracleDriverSemarchy xDM automatically recognizes the configuration properties from the environment variables. 
| The /samplesfolder in the Semarchy xDM package that you downloaded contains complete configuration samples using environment variables, in thesetenv_sample.shandsetenv_sample.batfiles. | 
Configuration file
You can define startup configuration properties in a single properties file.
When starting, by default, Semarchy xDM looks for a <USER_HOME>/.xdm/config.properties properties file containing the startup configuration. You can also change the location of this file using the xdm.config.file configuration property.
| Property (Environment Variable) | Description | 
|---|---|
| 
 | Startup configuration file path. Defaults to  | 
<tomcat_home>/bin/setenv.sh (Linux/UNIX)# Append this line to setenv.sh
CATALINA_OPTS="$CATALINA_OPTS -Dxdm.config.file=/etc/xdm/dev_001.properties"<tomcat_home>bin\setenv.bat (Windows)rem Append this line to setenv.bat
set "CATALINA_OPTS=%CATALINA_OPTS% -Dxdm.config.file=\<USER_HOME>\xdm\dev_001.properties"When running Tomcat as a process, you can quickly configure the startup configuration using this properties file.
To create the startup configuration:
- 
In the Home directory of the user starting the application server running Semarchy xDM, create a folder named .xdm.
- 
In that folder, create a config.propertiesfile, using one of the samples below.
Configuration file samples
The following samples define the repository datasources using a configuration file.
# Repository datasource
xdm.repository.driver=org.postgresql.Driver
xdm.repository.url=jdbc:postgresql://localhost:5432/postgres
xdm.repository.username=repository_user
xdm.repository.password=repository_password
# Repository read-only datasource credentials
xdm.repository.readonly.username=repository_readonly_user
xdm.repository.readonly.password=repository_readonly_password# Repository datasource
xdm.repository.driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
xdm.repository.url=jdbc:sqlserver://localhost:1433;databaseName=REPOSITORY
xdm.repository.username=repository_user
xdm.repository.password=repository_password
# Repository read-only datasource credentials
xdm.repository.readonly.username=repository_readonly_user
xdm.repository.readonly.password=repository_readonly_password# Repository datasource
xdm.repository.driver=oracle.jdbc.OracleDriver
xdm.repository.url=jdbc:oracle:thin:@localhost:1521:XE
xdm.repository.username=repository_user
xdm.repository.password=repository_password
# Repository read-only datasource credentials
xdm.repository.readonly.username=repository_readonly_user
xdm.repository.readonly.password=repository_readonly_password
# Set the current schema of the readonly user to the repository
xdm.repository.readonly.connectioninitsql=ALTER SESSION SET CURRENT_SCHEMA = repository_user| The /samplesfolder in the Semarchy xDM package that you downloaded contains a complete configuration property file sample namedconfig_sample.properties. |