Manage a Semarchy xDM instance in Azure
You can perform the main administrative tasks needed for your Semarchy using the Bash scripts listed below.
Other tasks, such as resizing the instances or databases or configuring the firewall rules, are performed as regular Azure tasks.
Download the scripts from the Semarchy Azure Templates Github repository, and install them in your environment or your Azure Cloud Shell.
Configure the Azure resources
You can configure the resources deployed in the instance, for example:
-
To scale the instance, you can change the size of the virtual machine, of the scale set virtual machines, or of the databases. You can also modify the scale set configuration to add more VMs.
-
To configure network rules or reinforce security, you can modify the application gateway configuration.
Refer to the Azure documentation for more information about these tasks and the configuration options of the deployed resources.
Add a new database
The az-xdm-instance-add-database
script creates a new database/schema - for example, for a new data location - and then automatically configures and restarts the Semarchy instance to take into account this new database.
az-xdm-instance-add-database.sh
[--resource-group=resource-group-name]
[--admin-password=admin-password]
[--db-server-password=database-server-password]
--db-name=<database-name>
[--db-password=database-password]
Parameters
--db-name
-
The name of the new database. This value is used for the name of the database created, for the user created for this database, as well as for the name of the datasource configured in the application server to connect this database.
Optional parameters
--resource-group
-
The resource group into which the instance is deployed. The resource group specified in the
$XDM_RESOURCE_GROUP
environment variable is used by default. --admin-password
-
The password of the instance administrator. The password specified in the
$XDM_ADMIN_PASSWORD
environment variable is used by default. --db-admin-password
-
The password of the database server administrator. The password specified in the
$XDM_DB_SERVER_PASSWORD
environment variable is used by default. --db-password
-
The password of the new database user to create. The password specified in the
$XDM_DB_PASSWORD
environment variable is used by default.
Configure the application server
The virtual machine and the scale set run Semarchy xDM in a Tomcat application server. This server reads its configuration from the file share in the storage account.
The file share, hosting the configuration and files used by all the Semarchy active and passive nodes, is organized as shown below:
-
/xdm-assets
-
/conf
This folder contains the Semarchy configuration files, including:-
semarchy.xml
: This file contains configuration elements of the Semarchy xDM application in Tomcat. See Tomcat Configuration File for more information. -
logging.properties
: This file contains the logging configuration of the Tomcat server. -
config.properties
: Contains the Semarchy xDM startup configuration, shared by the Active Virtual Machine and the Scale Set VMs. This configuration contains for example the repository connection information. Note that this file is copied in all the virtual machines, in the/etc/xdm/config.properties
location. -
local.keystore
: Contains the default local keystore used to encrypt secrets in the repository. It may be replaced by a user-defined key. See Secrets Management for more information. Note that this file is copied in all virtual machines and is referenced inconfig.properties
at its target location in the VMs (/etc/xdm/local.keystore
).
-
-
/lib
This folder contains additional libraries. These libraries will be copied in the active and passive VM’s, in Tomcat’slib
folder. -
/bin
This folder contains the startup configuration for the tomcat server running on the active and passive nodes.-
setenv.sh
: tomcat startup options for all nodes node, including java system properties. Note that this file references the startup configuration file at its target location in the VMs (/etc/xdm/config.properties
). -
setenv-active.sh
: specific options for the active node. This file does not exist by default. If it exists, it is used instead of setenv.sh for the active node.
-
-
You can use the content of the file share to configure the active and passive nodes. For example:
-
To modify the Semarchy xDM startup configuration in
conf/config.properties
. -
To add new Tomcat startup parameters using the
bin/setenv.sh
file. -
To add new libraries in the
/lib/
folder.
When you change the content of the file share, you must restart the instance to refresh the instance with these changes.
To configure the application server:
-
Download the configuration file that you want to modify, update it and re-upload it at the same location in the file share.
-
Upload additional libraries to the
/lib/
folder.
Restart the instance
The az-xdm-instance-upgrade
script restarts the Semarchy instance, for example after modifying its configuration.
az-xdm-instance-restart.sh
[--resource-group=resource-group-name]
[--admin-password=admin-password]
Example
az-xdm-instance-restart.sh --resource-group=xdm-production
Optional parameters
--resource-group
-
The resource group into which the instance is deployed. The resource group specified in the
$XDM_RESOURCE_GROUP
environment variable is used by default. --admin-password
-
The password of the instance administrator. The password specified in the
$XDM_ADMIN_PASSWORD
environment variable is used by default.
Upgrade the instance
The az-xdm-instance-upgrade
script upgrades the Semarchy instance to a given version.
az-xdm-instance-upgrade.sh
--resource-group=resource-group-name
--xdm-version=version
[--admin-password=admin-password]
[--db-server-password=db-server-password]
[--repo-ro-password=repo-ro-password]
[--backup-suffix=backup-suffix]
[--backup]
Supported upgrade methods
This script supports:
-
In-place upgrades, executed on a running instance.
For an in-place upgrade, it is recommended to backup the existing resources by using the
--backup
parameter. -
Out-of-place upgrades, executed on a cloned instance. This method is recommended for major updates (for instance from 5.2.x to 5.3) on production environments. To perform such an upgrade, proceed with the following steps:
-
Clone the current instance in another resource group by executing the
az-xdm-instance-clone.sh
script (see clone the instance for details). -
Execute the
az-xdm-instance-upgrade.sh
script (see details below) on the cloned instance. -
Test the new instance.
-
Change settings on your DNS server: Assign the new public (active) IP address to the existing DNS name of the Semarchy server.
-
|
For more details about the in-place and out-of-place upgrade methods, see Upgrade Semarchy xDM. |
Upgrade operations performed
The operations performed by this script depend on the type of upgrade:
-
For major upgrades (from 5.1.x or 5.2.x to 5.3.y), the script performs the following operations:
-
Create backup resources if requested using the
--backup
parameter and--backup-suffix
parameters. -
Create a new active virtual machine.
-
Set the startup configuration, based on the provided parameters and the repository connection information from the previously used
semarchy.xml
file. -
Generate a local JKS key for secrets encryption (see Secrets management for details).
-
Run the repository upgrade on the new active virtual machine.
-
Create datasources on the upgraded instance based on the content of the previously used
semarchy.xml
file -
Create a new Scale Set and deploy the new Semarchy passive war file.
-
-
For minor upgrades, the script performs the following operations:
-
Create backup resources if requested using the
--backup
and--backup-suffix
parameters. -
Create a new active virtual machine.
-
Deploy the new Semarchy active war file on the new active virtual machine.
-
Reimage the existing Scale Set to use the new version and deploy the new Semarchy passive war file.
-
Examples
az-xdm-instance-upgrade.sh
--resource-group=xdm-production
--xdm-version=5.3
--backup
az-xdm-instance-upgrade.sh
--resource-group=xdm-production
--xdm-version=5.2.3
az-xdm-instance-upgrade.sh
--resource-group=xdm-production
--xdm-version=5.1
Parameters
--resource-group
-
The resource group into which the instance is deployed. The resource group specified in the
$XDM_RESOURCE_GROUP
environment variable is used by default. --xdm-version
-
The Semarchy version to which you want to upgrade. This version may be provided in the following format:
-
A 2 digits minor version of Semarchy (e.g., 5.2): In that case, the template upgrades the latest patch of the minor version specified.
-
A 3 digits patch version of Semarchy (e.g., 5.2.1). In that case, the template upgrades to that product version.
-
Optional parameters
--admin-password
-
The password of the instance administrator. The password specified in the
XDM_ADMIN_PASSWORD
environment variable is used by default. --db-server-password
-
The password of the database administrator. The password specified in the
XDM_DB_SERVER_PASSWORD
environment variable is used by default. --repo-ro-password
-
The password of the repository read-only user (only applicable to version 5.3 and higher). The password specified in the
XDM_RO_USER_PASSWORD
environment variable is used by default. --backup
-
Use this option to backup databases, virtual machines, and scale set resources. The backup is disabled by default.
--backup-suffix
-
Use this option to define the suffix added to name of the backup resources created by the
--backup
flag. Resources cannot be renamed, so make sure to set a suffix that you can keep if you need to use the backups. If you do not specify the suffix, a random value is generated.
|
Clone the instance
The az-xdm-instance-clone
script clones a Semarchy instance in a separate resource group.
az-xdm-instance-clone.sh
--origin-resource-group=origin-resource-group-name
--destination-resource-group=destination-resource-group-name
--instance-name=instance-name
[--admin-password=admin-password]
[--db-server-password=db-server-password]
Example
az-xdm-instance-clone.sh
--origin-resource-group=xdm-production
--destination-resource-group=xdm-production-clone
--instance-name=xdm1
Parameters
--origin-resource-group
-
The resource group from which the instance is cloned. The resource group specified in the
XDM_ORIGIN_RESOURCE_GROUP
environment variable is used by default. --destination-resource-group
-
The resource group where the instance is cloned. The resource group specified in the
XDM_DESTINATION_RESOURCE_GROUP
environment variable is used by default. If the provided resource group exists, it is used, otherwise, it is created by the script (Note that the user who runs the script should have sufficient privileges to create resource groups). --instance-name
-
The prefix for all the resources in the cloned instance. The instance name specified in the
XDM_INSTANCE_NAME
environment variable is used by default.
Optional parameters
--admin-password
-
The password of the instance administrator. The password specified in the
XDM_ADMIN_PASSWORD
environment variable is used by default. --db-server-password
-
The password of the database administrator. The password specified in the
XDM_DB_SERVER_PASSWORD
environment variable is used by default.
|
Change the instance admin password
The az-xdm-instance-reset-admin
script changes the admin password of the Semarchy instance.
az-xdm-instance-reset-admin.sh
[--resource-group=resource-group-name]
[--admin-password=new-admin-password]
Optional parameters
--resource-group
-
The resource group into which the instance is deployed. The resource group specified in the
XDM_RESOURCE_GROUP
environment variable is used by default. --admin-password
-
The new password of the instance administrator. The password specified in the
XDM_ADMIN_PASSWORD
environment variable is used by default.
|
This script changes the password of the instance administrator but does not change the password of the first Semarchy xDM administrator user created during the deployment. |