Privilege Manager High Availability Setup

This topic explains the steps involved to set up DelineaPrivilege ManagerHigh Availability, also known as clustering.

ha

Prerequisites

Make sure that Privilege Manageris installed and working on a primary node with an existing database.

To cluster Privilege Managera secondary server must be prepared with the proper Privilege Managerprerequisites. The prerequisites check can be performed via standard Privilege Manager setup.exe. However, exit that automated installer once all prerequisites clear.

Except for the Operating System, the following prerequisites will be installed automatically by our installer. If you already have some of them installed or wish to install them yourself then the installer will skip over them.

System Requirements Overview

  1. Windows Server 2016 or newer
  2. Microsoft SQL Server 2016 or newer
  3. Microsoft Internet Information Services (IIS) 10 or newer
  4. Microsoft .NET Framework 4.6.1 or newer

Using the Installer to Install/Confirm Prerequisites

The latest version of Privilege Manager is available for download. By clicking the Installer (.exe) link, a setup.exe file will be downloaded to your machine. It is recommended to run the setup.exe file as an administrator.

The setup executable will ONLY be used to install/confirm all prerequisites are installed on the web server. After confirming the prerequisites, the installer will be closed and a manual installation will be completed. The manual installation will allow for separate databases and custom file locations. Do NOT complete the installation with the setup executable.

Running the setup.exe will begin an installation wizard. This wizard will ONLY be used to install any remaining prerequisites required on the web server. The wizard will walk through the initial installation steps, beginning with a Welcome page.

  1. On the Welcome dialog, verify that Privilege Manager is selected and select the checkbox if not already checked.

    Welcome dialog

  2. Click Next.

  3. On the License dialog review the End User License Agreement (EULA) and click Accept License.

  4. On the Database dialog select Connect to an existing SQL Server, click Next.

  5. The Prerequisites dialog helps you to ensure everything that is required gets installed for Privilege Manager. Click Fix Issues to automatically install the necessary prerequisites.

  6. Close the installer once all prerequisites are successfully installed.

Do NOT continue installing the products with this installer.

Manual Set-up of Secondary Node

In this procedure you will:

  1. Copy the web application files from the primary server to the secondary server.
  2. Use those copied files to setup and configure the secondary Privilege Manager server.
  3. Use the Internet Information Services Manager to setup Application Pools.
  4. Convert application pools to applications.
  5. Configure Authentication.
  6. Set the Preload Status.
  7. Change the Disable Overlapped Recycle setting.
  8. Edit the TMS/Worker Web.config file.

Copy Web Application Files from Primary to Secondary Servers

  1. On the primary server, decrypt the connectionStrings.config by running the following command:

    Copy
    C:\Windows\Microsoft.NET\Framework64\v4.0.30319\aspnet_regiis.exe -pd "connectionStrings" -app "/Tms"
  2. Select and copy all contents of the Privilege Managerweb application folder at

    Copy
    C:\inetpub\wwwroot\TMS\

    Including the unencrypted connectionStrings.config file.

  3. On the secondary server, create the same folder path.

  4. Paste the entire contents of the Privilege Manager web application folder from the primary web server to the similar location on the secondary web server.

    File destination

Setting up Application Pools

  1. Open Internet Information Services Manager (inetmgr).
  2. Under your local server, right-click Application Pools and select Add Application Pool...
  3. Add three new application pools.

    1. TMS - Under General > Start Mode select OnDemand (Default).

    2. TMSAgent - Under General > Start Mode select AlwaysRunning.

    3. TMSWorker - Under General > Start Mode select AlwaysRunning.

      Application Pools

  4. For each of the 3 app pools (TMS, TMSAgent, and TMSWorker),

    1. right-click on each app pool,

    2. select Advanced Settings...

    3. then the Identity box in the "Process Model" section,

    4. click the three dots on the right of the box.

      Navigate to Custom Account

    5. Select the Custom Account radio button,

    6. Click Set, enter your service account's name and password.

      Set name and password

    7. Click OK.

Converting the Application Pools

  1. Right-click Default Web Site in IIS and select Add Virtual Directory….

    Virtual Directory

  2. Select an alias for your Privilege Manager. The alias is what will be appended to the website. For instance, "TMS" in http://myserver/TMS.

  3. Next, enter the physical directory where you unzipped Privilege Manager(i.e., 'C:\inetpub\wwwroot\TMS').

    Physical directory

  4. Click OK.

  5. In the tree, right-click the new virtual directory and select Convert to Application.

    1. Set the Application Pool to the one called TMS.

    2. Click OK.

      Convert Application Pool to TMS

  6. In the virtual directory expand the new TMS site,

    1. right click the Agent Subfolder and select Convert to Application.
    2. Set the Application Pool to the one called TMSAgent, click OK.
  7. In the virtual directory navigate to the ServiceBus Subfolder.

    1. Right-click and select Convert to Application.

    2. Set the Application Pool to the one called TMSWorker you created earlier, click OK.

      Convert Application Pool to TMSWorker

  8. In the virtual directory select the Services Subfolder,

    1. Right-click the new virtual directory and select Convert to Application.
    2. Ensure that the Application Pool is set to the one called TMS, click OK.
  9. In the virtual directory select the Setup Subfolder,

    1. Right-click the new virtual directory and select Convert to Application.
    2. Ensure that the Application Pool is set to the one called TMS, click OK.
  10. In the virtual directory select the Worker Subfolder,

    1. Right-click the new virtual directory and select Convert to Application.
    2. Set the Application Pool to the one called TMSWorker, click OK.

Setting Authentication

  1. Select your TMS virtual directory.

    1. Double-click Authentication in the features pane.

    2. Make sure that only Anonymous Authentication is set to Enabled. Everything else should be set to disabled.

      Verify Authentication for TMS

  2. Select the Setup directory.

    1. Double click Authentication in the features pane.

    2. Make sure that Anonymous Authentication and Windows Authentication are both set to Enabled and everything else is disabled.

      Verify Authentication for Setup

  3. Select the Worker.

    1. Double-click Authentication in the features pane and make sure that Anonymous Authentication and Windows Authentication are both set to Enabled and everything else is disabled.

      Verify Authentication for the Worker

Setting the Preload Status

  1. Right-click the TMSWorker application.

  2. Select Advanced settings.

  3. Under General > Preload Enabled, change the setting to True.

    alt

HA Deployment

Perform the following IIS changes as part of the best practices setup.

  1. In IIS, right-click the TMSWorker application pool.

  2. Select Advanced Settings.

  3. Under the Recycling section, change Disable Overlapped Recycle to True.

    alt

  4. Navigate to C:\inetpub\wwwroot\TMS\Worker\Web.config.

  5. Locate the system.webServer section and add:

    Copy
     <applicationInitialization doAppInitAfterRestart="true">
         <add initializationPage="/status/ping" /> </applicationInitialization>

    The section should now look like this:

    Copy
     <system.webServer>
         <applicationInitialization doAppInitAfterRestart="true">         <add initializationPage="/status/ping" />     </applicationInitialization>      <modules runAllManagedModulesForAllRequests="true">         <remove name="UrlRoutingModule"/>         <add name="UrlRoutingModule" type="System.Web.Routing.UrlRoutingModule, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"/>     </modules>     <handlers>         <add name="UrlRoutingHandler" preCondition="integratedMode" verb="*" path="UrlRouting.axd"             type="System.Web.HttpForbiddenHandler, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"/>     </handlers>     <security>         <authorization>             <add accessType="Allow" users="?"/>         </authorization>     </security> </system.webServer>

Folder Permissions to C:\Windows\Temp

  1. Navigate to the C:\Windows\TEMP folder.

  2. Right-click the folder and select Properties | Security | Advanced.

  3. Click Add and Select a principal.

  4. Ensure the domain machine is listed as the Location and type the service account into the Enter the object name to select field.

  5. Click Check Names and Enter network credentials for accessing your domain machine.

    Check Names

  6. Click OK.

  7. Under Basic permissions, select the Modify checkbox.

    Modify checkbox

  8. Verify your service account has Modify, Read & execute, List folder contents, Read, and Write permissions for the C:\Windows\TEMP folder.

  9. Click OK, then Apply.

Folder Permissions to the Privilege ManagerApplication Folder

  1. Navigate to the Privilege Managerapplication folder at C:\inetpub\wwwroot\TMS.

  2. Right-click the folder and select Properties | Security | Advanced.

  3. Select principal.

  4. Ensure the domain machine is listed as the Location and type the service account into the Enter the object name to select field.

  5. Click Check Names and Enter network credentials for accessing your domain machine.

    Check names

  6. Click OK.

  7. Under Basic permissions, select the Modify checkbox.

    Modify checkbox

  8. Verify your service account has Modify, Read & execute, List folder contents, Read, and Write permissions for the C:\Windows\TEMP folder.

  9. Click OK, then Apply.

The application folder only needs Write and Modify permissions during the installation or during an upgrade. You can remove these once the installation process is complete.

Upgrade Prep

Following these changes, ensure that

  • all server nodes are up and running without error conditions.
  • all server nodes have access to the NuGet repository.
  • for upgrades login into one of the server nodes directly and not the clustered shared address.
  • Initiate the upgrade, the selected node will deploy all upgrade components to all other nodes within the cluster.

Permission to Certificate Private Key (prior to 10.6 only)

This is only required for Privilege Managerprior to release 10.6.

TMS requires Read access to the private key of the certificate being used for the HTTPS binding. To set this:

  1. Open mmc.exe as an administrator.
  2. Add the certificate manager snap-in choosing to manage certificates for the computer account (File | Add/Remove Snap-in…)
  3. Click Certificates,
  4. then Add | Computer account | Next | Local computer | Finish | OK.
  5. Find the certificate that the HTTPS binding for your site is using.
  6. Right-click on the certificate and select All Tasks | Manage Private Keys.
  7. Grant Read access to the identity account for your application pools.

If the "Manage Private Keys" option is not available, you can set this permission in PowerShell.

Verify Login on Secondary Node

  1. Navigate to Privilege Manager, ex: http://localhost/TMS. You should be able to authenticate to Privilege Manager.
  2. After logging in, all policies and all data accessible on the primary node should be accessible on the secondary node.

Re-encrypt ConnectionStrings.config

  1. On the primary node, run the following command to re-encrypt the connectionStrings.config file:

    Copy
    C:\Windows\Microsoft.NET\Framework64\v4.0.30319\aspnet_regiis.exe -pe "connectionStrings" -app "/Tms"
  2. On the secondary node, run the same command to re-encrypt the connectionStrings.config file:

    Copy
    C:\Windows\Microsoft.NET\Framework64\v4.0.30319\aspnet_regiis.exe -pe "connectionStrings" -app "/Tms"

Privilege Managerhas now successfully been clustered. A load balancer, GTM, VIP, etc. can be used to manage the traffic. The settings to configure this will be handled on the side of this infrastructure piece and is beyond the scope of this document. Contact Delinea's Professional Services team if additional consultation is required.

Delinea requires that sticky sessions are enabled on the load balancer to prevent a user from bouncing between servers on each request of a single session.