Be careful, some specific steps are required to configure Milestone XProtect and SQL on the virtual IP address else the failover is not working.
1. Launch the SafeKit console
- Launch the web console in a browser on one cluster node by connecting to
http://localhost:9010
. - Enter
admin
as user name and the password defined during installation.
You can also run the console in a browser on a workstation external to the cluster.
The configuration of SafeKit is done on both nodes from a single browser.
To secure the web console, see 11. Securing the SafeKit web console in the User's Guide.
2. Configure node addresses
- Enter the node IP addresses.
- Then, click on
Apply
to save the configuration.
If node1 or node2 background color is red, check connectivity of the browser to both nodes and check firewall on both nodes for troubleshooting.
This operation will place the IP addresses in the cluster.xml
file on both nodes (more information in the training with the command line).
4. Configure the module
- Choose an automatic start of the module at boot without delay.
- Normally, you have a single heartbeat network on which the replication is made. But, you can define a private network if necessary.
- Check that the replicated directories are installed on both nodes and contain the application data.
Replication of data and also logs is required for a database.
You can add new replicated directories as needed. - Enter a virtual IP address. A virtual IP address is a standard IP address in the same IP network (same subnet) as the IP addresses of both nodes.
Application clients must be configured with the virtual IP address (or the DNS name associated with the virtual IP address).
The virtual IP address is automatically switched in the event of a failure. start_prim
andstop_prim
must contain starting and stopping of the Milestone XProtect and SQL application.
You can add new services in these scripts.
Check that the names of the services in these scripts are those installed on both nodes, otherwise modify them in the scripts.- Stop the services configured in
start_prim
on both nodes. - On Windows and on both nodes, with the Windows services manager, set
Boot Startup Type = Manual
for all the services registered instart_prim
(SafeKit controls the start of services instart_prim
).
If SQL is on the management server:
- The SQL system databases (like master.mdf and mastlog.ldf) must be located in the same directories on both nodes. The directories must be configured as replicated.
- SQL must be also installed at the same location in the file system on both nodes because the read-only SQL resource database is located in the binary and is required for the failover. This database does not need to be replicated.
- The SQL Milestone databases (.mdf and .ldf) must be located in the same directories on both nodes. The directories must be configured as replicated. Milestone databases are as follows according this article.
Note that if a process name is displayed in Process Checker, it will be monitored with a restart action in case of failure. Configuring a wrong process name will cause the module to stop right after its start.
The "Apply" button will report the configuration in the userconfig.xml
, start_prim
, stop_prim
files on both nodes (more information in the training with the command line).
7. Go to desktop of node 1 and set the virtual IP address in internal Milestone files
Since Milestone 2022 R3, this step is not useful and will be made automatically with "Server Configurator - Registering servers - http://virtual-IP" in a next step.
In a Powershell command line as Administrator, execute on node 1 this script:
c:/safekit/modules/milestone/bin/UpdateAuthServerUri.ps1
This script sets the virtual IP address in 2 internal Milestone files:
C:\ProgramData\Milestone\XProtect Management Server\ServerConfig.xml
<AuthorizationServerUri>http://<virtual-ip>/IDP</AuthorizationServerUri>
C:\Program Files\Milestone\XProtect Management Server\IIS\IDP\appsettings.json
"Authority": "http://<virtual-ip>/IDP"
We assume at this step that the virtual IP address has been correctly configured in the previous steps (the script uses the virtual IP address entered in the SafeKit console and stored in userconfig.xml
).
Note that the same procedure is required when Milestone is running with Microsoft Cluster else there is a reconnection problem of recording servers: https://developer.milestonesys.com/s/article/RS-goes-offline-mode-after-switching-the-Management-Server-cluster-node.
8. Start node 1 as primary in the console, the node with up-to-date data
We assume since Step 7 that node 1 has the up-to-date replicated directories.
Force the start of node 1 as primary. When node 2 will be started, all data from node 1 will be copied to node 2.
If you make the wrong choice, you run the risk of synchronizing outdated data on both nodes.
It is also assumed that the Milestone XProtect and SQL application is stopped on node 1 so that SafeKit installs the replication mechanisms and then starts the application in the start_prim
script.
9. Wait for the transition to ALONE (green)
- Node 1 should reach the ALONE (green) state, which means that the
start_prim
script has been executed on node 1.
If the status is ALONE (green) and the application is not started, check output messages of start_prim
in the Application Log of node 1.
If node 1 does not reach ALONE (green) state, analyze why with the Module Log of node 1.
If the cluster is in WAIT (red) not uptodate - STOP (red) not uptodate
state, stop the WAIT node and force its start as primary.
10. In the desktop of node 1, stop, then register on the vitual IP address and restart the Milestone Management Server
Execute the following bullets on node 1 according the menu in the image:
- Right-click on the Milestone Management Server icon in the taskbar.
- Stop Management Server Service
- Then choose Server Configurator... and register the virtual IP address.
- Start Management Server Service
This procedure registers the node 1 management server in the SQL database (running on node 1) through a connection to the virtual address.
Before Milestone 2022 R3 version, the registration may have deleted the virtual IP address configuration in the internal Milestone files. In this case, repeat Step 7.
Note: To register a version before Milestone 2020 R2, use Change encryption settings...
11. In the desktop of node 1 with Milestone Management Client, set the virtual IP address in URLs for services and network
Since Milestone 2022 R3, this step is not useful and has been made automatically with "Server Configurator - Registering servers - http://virtual-IP".
According the image:
- Start Milestone XProtect Management Client on node 1.
- In the Tools menu, select Registered Services.
- In the Add/Remove Registered Services window, select a service in the list and click on Edit.
- In the Edit Registered Service window, change the URL address of the service with the same URL address but containing the virtual IP address.
- Repeat these steps for all services listed in the window.
- In the same window, click on Network.
- In the Network Configuration window, change the URL address of the server with the same URL address but containing the virtual IP address.
12. In the desktop of node 1 with Milestone Management Client, set the administrator roles to ensure a correct failover
If Milestone "Windows authentication" has been configured with an Active Directory, the user/password will be retrieved in the external AD on the secondary node after a failover, so there is no special configuration.
When you start the Milestone XProtect Management Client, you have to authenticate either with "Windows authentication" or "Basic authentication" (click here to see the screenshot).
Open Milestone XProtect Management Client and in Security / Roles (see image)
- Set the Windows group BUILTIN\Administrators . Thus an administrator user on the secondary will be able to connect to Milestone on the secondary with "Windows authentication".
- Create a user with a "Basic authentication" (Admin in the image) to be sure to re-authenticate on the secondary node after a failover. For "Basic authentication", the user/password is stored in the SQL database and will be retrieved on the secondary node after a failover.
By setting the BUILTIN\Administrators group, you will be able to authenticate on the seconday node with a local Windows administrator.
Else no authentication will be possibe with a local Windows account on the secondary after a failover.
It's because the BUILTIN\Administrators group has the same SID on both nodes. For other local groups or local users, authentication will not be possible on the secondary because SIDs are different between both nodes even if they have the same name.
13. Go to the desktop of node 2 and set the virtual IP address in internal Milestone files
Since Milestone 2022 R3, this step is not useful and will be made automatically with "Server Configurator - Registering servers - http://virtual-IP" in a next step.
In a Powershell command line as Administrator, execute on node 2 this script:
c:/safekit/modules/milestone/bin/UpdateAuthServerUri.ps1
This script sets the virtual IP address in 2 internal Milestone files:
C:\ProgramData\Milestone\XProtect Management Server\ServerConfig.xml
<AuthorizationServerUri>http://<virtual-ip>/IDP</AuthorizationServerUri>
C:\Program Files\Milestone\XProtect Management Server\IIS\IDP\appsettings.json
"Authority": "http://<virtual-ip>/IDP"
14. In the desktop of node 2, register the management server on the vitual IP address
- Choose Server Configurator in the taskbar of node 2 and register it on the virtual IP address (see image).
- Then Stop Management Server Service.
The account of the user executing the registration on node 2 must have the administrator role in Milestone on node 1.
If it is the local administrator on node 2 who makes the registration, the built-in Windows group BUILTIN\Administrators
must have been set in Management Client / Security / Roles at Step 12. Else the registration will not work.
This procedure registers the node 2 management server in the SQL database (running on node 1) through a connection to the virtual address.
With a version of Milestone before 2022 R3, the registration may have deleted the virtual IP address configuration in the internal Milestone files. In this case, repeat Step 13.
15. Start node 2
- Start node 2 with its contextual menu.
- Wait for the SECOND (green) state.
Node 2 stays in the SECOND (magenta) state while resynchronizing the replicated directories (copy from node 1 to node 2).
This may take a while depending on the size of files to resynchronize in replicated directories and the network bandwidth.
To see the progress of the copy, see the Module Log of node 2 with the verbose option without forgetting to refresh the window.
16. Verify that the cluster is operational
- Check that the cluster is green/green with Milestone XProtect and SQL services running on the PRIM node and not running on the SECOND node.
Only changes inside files are replicated in real time in this state.
Components that are clients of Milestone XProtect and SQL services must be configured with the virtual IP address. The configuration can be done with a DNS name (if a DNS name has been created and associated with the virtual IP address).
17. Configure the virtual IP address in recording servers
- Either install the recording servers, specifying the virtual IP address in the installation URL.
-
Or, on the recording servers side, set the virtual IP address in the following fields of
C:\ProgramData\Milestone\XProtect Recording Server\RecorderConfig.xml
<server><address>
<server><authorizationserveraddress>
- Connect the Milestone Management Client and the Milestone Smart Client on the virtual IP address.
18. Management Client and Smart Client are not functioning properly after node switch
In a clustered XProtect® Management Server setup, Smart Client and Management Client show various issues after a node switch. The issue is related to tokens being generated on different nodes before and after the node switch, and to problems accessing certain certificates needed for token validation. A solution is available (for versions 2022 R3 to 2023 R2) — this Milestone article explains in detail how to apply the solution.
Read the Milestone KB article.
The issue is solved in Milestone 2023 R3.
19. Testing
- Stop the PRIM node by scrolling down its contextual menu and clicking Stop. Do not use swap for a first test (see why below).
- Verify that there is a failover on the SECOND node which should become ALONE (green).
- And with Microsoft Management Console (MMC), check the failover of Milestone XProtect and SQL services (stopped on node 1 in the
stop_prim
script and started on node 2 in thestart_prim
script).
If everything is okay, initiate a start on node1, which will resynchronize the replicated directories from node2.
If things go wrong, stop node2 and force the start as primary of node1, which will restart with its locally healthy data at the time of the stop.
The swap involves a stop-start of the PRIM, which will resynchronize the data from node2 immediately after its stop, leaving no chance for a restart on healthy data if there is a replication configuration issue.
If the Milestone XProtect and SQL application is not started on node 2 while the state is ALONE (green), check output messages of the start_prim
script in the Application Log of node 2.
If ALONE (green) is not reached, analyze why with the Module Log of node 2.