Installing Elasticsearch

If you want to use Audit in your environment, you must install Elasticsearch using the Elastic installer. To access the Elasticsearch installation package, go to the Community.

Special considerations

  • Ensure you complete the pre-installation steps. For more information, see Pre-Installation.
  • You do not need to install Java (Development Kit). This is because the Elastic installer already includes Java, which has been tested and works with the version of Elastic contained in the installation package. For questions, email Relativity Support.
  • For system requirements, see Elasticsearch system requirements.

Running the Elastic installer

  1. Download the Elastic installer, and extract the contents into a folder on your C: drive.
  2. Right-click DataTron.exe, and then select Run as administrator.

Creating the response file

The first page in the installer contains setup for creating the response file.

  1. On the response file utility, click Create Blank Response File. This creates a file called DataGridResponseFile in the same folder as DataTron.exe.
  2. Complete the following fields: 
    • Cluster Name - enter a name for your cluster.
    • Node Name - enter a name for your node. Double-click on the text box to auto-fill the machine name. Update the name to the FQDN of the machine.
    • Select a role for the node. See Elasticsearch system requirements for more information.

      Note: Any cluster that will contain monitoring data must have at least one ingest node.

      1. Master Node Role - the node within a cluster that manages changes across an entire cluster.
      2. Data Node Role - the node that stores data within a cluster.
      3. Monitoring Node Role - the node that monitor the health of your Elasticsearch cluster.
      4. Ingest Node Role - the node that pre-processes documents before the actual document indexing happens.
    • Number of Master Nodes - enter the number of master nodes. This must be an odd number.
    • Data Path - double-click on the text box to select a path to store node data. This must be a local drive.
    • Backup Location - this must be a UNC path to a file share. The Relativity service account must have full control on the share. For example; \\fileserver\datagridbackup
    • Logs Path - double-click on the text box to select a path to store node logs. This must be a local drive.
    • Production REST Username - create a user name used to access the node. This user will have all permissions and capabilities.
    • Production REST Password - create a password used to access the node.
    • Monitoring REST Username - create a user name used to access Kibana. This user will have all permissions and capabilities.
    • Monitoring REST Password - create a password used to access Kibana.
    • Relativity Service Account Username - enter the user name used to access the Relativity service account. Use the domain\user name format.
    • Relativity Service Account Password - enter the password used to access the Relativity service account.
    • Unicast Hosts - enter a list of all master nodes in the cluster without spaces and separated by commas. For example, localhost:9300, localhost:9301.
    • (Optional) Select whether you are using a separate monitoring cluster:
      • Separate monitoring cluster - select this checkbox if you have a separate monitoring cluster, and this node is not part of it.
      • Part of monitoring cluster - select this checkbox if you have a separate monitoring cluster, and this node is part of it.
    • (Optional) Monitoring Hosts - enter the URIs of the master nodes in the monitoring cluster. For example, http://monitoringnodename:9000.
    • (Optional) Port - enter the port used to access the node. If you leave this box empty, it defaults to 9200.
    • Authentication Web Server - enter the name of the Relativity web server.

Once you complete all the fields, click Update Response File. Then, click Next.

Installing a node

The next page in the response file contains setup for installing a node as well as installing Kibana.

To install a node automatically, select Run all tasks, and then select Production Install or Monitoring Install.

You can also run through the tasks manually by clicking each button in the following order:

  • Copy or Register Data Grid Package - opens a dialog box to browse for a ocation. If the root drive is selected, a folder called RelativityDataGrid will be created at the root level. You can also choose a folder on the drive which will create the RelativityDataGrid in that folder.
  • Update YML File - updates the Elasticsearch .yml configuration with the values you entered in the previous form.
  • Get Java Installations - gets the installed JDKs that are located in a \Program Files\Java\ subdirectory. and populates the Select a Java Installation field. If the program can't find any JDK installations on your machine, the open JDK folder in the Relativity Data Grid folder will be automatically populated. The path should be in the format C:\Program Files\Java\jdk<version>. For example, C:\Program Files\Java\jdk11.
  • Select a Java Installation – Double click any java installation in the drop down to populate the Selected Java Installation field

  • Get Java Home - gets the KCURA_JAVA_HOME environment variable and populates the Selected Java Installation field.
  • Set Java Home - sets the KCURA_JAVA_HOME environment variable to the value in the Selected Java Installation field.
  • Install Elastic Service - installs the Elasticsearch service.
  • Grant Logon as Service Rights - grants the account the ability to log in and run services.
  • Update Service User Account - changes the login user to the service account.
  • Start Service - starts the Elasticsearch service.
  • Get Web Cert - downloads an authentication certificate using the Authentication Web Server provided in the previous form.
  • Install Web Cert - installs the authentication certificate to the Java Keystore. To use this button, Get Web Cert must be run first.
  • Configure Firewall - creates a firewall rule which allows incoming communication for the service.

(Optional) Installing Kibana

To install Kibana, complete the following:

Note: If you want to configure TLS on your cluster, you must do so before installing Kibana. See Installing Elasticsearch.

  1. Next to Production Cluster Hosts, enter the names of the hosts for Kibana to connect to.
      Notes:
    • If you have a separate monitoring cluster, these should be the hosts of that monitoring cluster.
    • If you don't have a separate monitoring cluster, these should be the hosts of your production cluster.
  2. Click Install Kibana, and then select a location to extract the files.
  3. Click Start Kibana.

Enabling basic security

Note: Complete the following steps for only one node in the cluster once the minimum number of master nodes are running. Make sure the node is running by navigating to http://nodename:9200/_cat?nodes before using any of the below buttons.

  1. Click Enable Basic Security. This button starts the trial license on the cluster and creates a genpassword.txt file in the RelativityDataGrid folder.
  2. Click Create Elastic REST User. This creates an Elasticsearch user with the credentials provided in the previous form.
  3. Click Enable Monitoring on This Cluster to let Kibana receive and display monitoring data about this cluster.

Licensing, testing, and backup

The final page in the Elastic installer includes setup for licensing and cluster tests and backups.

Licensing

Note: In order to set up licensing, you must first create a self-signed certificate. See Installing Elasticsearch.

  • Is SSL enabled - select this checkbox to indicate that you have created a certificate authority.
  • Get License - retrieves information about the license currently being used.
  • Update License - updates the license. If there is a license.json file in the DataTron.exe folder, that file will be used. If not, you must manually enter the new license. TLS must be setup on the cluster for this button to function. For more information, see Elastic TLS configuration.

Cluster tests and setups

  • Test Nodes - retrieves information about the current node.
  • Create Test Index - creates a test index that you can use to debug.
  • Register Backup Location - registers a location so Elasticsearch knows where to store backups.
  • Check Backup Location - retrieves information about the currently registered backup location.
  • Snapshot Test - creates a snapshot to confirm the backup is working.

(Optional) Curator setup

If you want to use Curator, which is responsible for automatically creating snapshots, deleting snapshots, and deleting indixes, complete the following:

  1. Select Customize curator scripts.
  2. Click Curator Setup to install Curator.
  3. Configure the following settings:
    • How frequently would you like to snapshot? - enter how frequently to run the script that saves snapshots of indixes/nodes.
    • How frequently would you like to delete old snapshots? - enter how frequently to run the script that deletes old snapshots.
    • How frequently would you like to delete old monitor indices? - enter how frequently to run the script that deletes old monitoring indices.
    • After how long should a monitoring index be deleted? - enter the age (in days) after which an index will be deleted by the monitoring cleanup script.
    • After how long should a snapshot be deleted? - enter the age (in days) after which a snapshot will be deleted by the snapshot cleanup script.

Instance settings

Note: After you successfully run the Elastic installer, you must update the following instance settings in Relativity.

  • ElasticsearchMajorVersion - specifies the major version of Elasticsearch that the cluster is running
  • ESIndexCreationSettings - edit the ESIndexCreationSettings entry in Instance Settings to update the template if your setup requires shard or replication modifications. Always update the template through these instance settings to keep templates consistent across Relativity and Elasticsearch.
  • ESIndexPrefix - enter a unique prefix for you instance of Relativity. This prefix lets you differentiate data from instance to instance within the cluster.
  • AuditDataGridEndpoint - enter the endpoint for the Elasticsearch cluster. This value is required to activate Data Grid operation for the Relativity instance (http://client:9200).
  • DataGridEndpoint- enter the endpoint for the Elasticsearch cluster. This value is required to activate Data Grid operation for the Relativity instance (http://client:9200).

Agents

Note: After you successfully run the Elastic installer, you must add the following agents to Relativity.

Agent name Requirement information Function Agent type
Data Grid Audit Migrator Only 1 per core on the agent server. Up to 16 agents per environment. A Data Grid Audit Migrator agent migrates audit data from SQL to Elasticsearch for any workspace that has Audit installed. The frequency with which this agent checks for migrations and runs the migrations is controlled by the agent run interval value. Multiple-installation
Data Grid Audit Deleter 1 per environment required. Up to 4 agents per environment.

The Data Grid Audit Deleter agent is an off-hour agent that deletes all audits from SQL that have been successfully migrated to Elasticsearch. Along with un-migrated audits, it will leave other existing audits in SQL for a configurable number of days for billing purposes.

Single-installation
Data Grid Audit Reporter (Optional) 1 per environment The Data Grid Audit Reporter agent reviews the audit queue for errors that occurred during migration from SQL to Elasticsearch. This agent triggers a Relativity error based on the agent's run interval. This agent is set to an hourly run interval by default. Single-installation
Data Grid Audit Manager Only 1 per environment Populates filters in the Audit application. Single-installation
Data Grid Manager Only 1 per environment

A Data Grid Manager agent is an off-hours agent responsible for Data Grid enabled workspace management, including deleting outdated search results cache tables and monitoring Data Grid index conditions.

Note: If you've already installed this agent with Data Grid installation, you don't need to add another.

Single-installation

For more information on installing agents, see Adding and editing agents.

Elastic TLS configuration

Configuring TLS is required to apply the Elastic production license in Elastic 6.6.0. The Elastic installer includes a script called ElasticCertificateTool.ps1. The script is found in the DataTronCertifcateUtility.zip. This script gives you four options for configuring TLS:

  • Option 1: Set up SSL for Elastic using a self-generated certificate authority (CA).
  • Option 2: Convert certificates from CER and PFX format to PEM and Key
  • Option 3: Set up SSL for Elastic using an externally generated TLS chain.
  • Option 4: Exit the script

To configure TLS on your cluster, complete the following steps:

  1. Stop the Elastic service on all servers in the cluster.
  2. Navigate to the folder containing the Elastic installer and run ElasticCertificateTool.ps1 in PowerShell as an administrator.
  3. In PowerShell, enter 1 or 2 depending on which option you want to select.
    • Enter 1 to create a self-signed certificate for the cluster. The generated certificate must be installed to the trusted root store on all agent and web servers. If you select this option, Option 2 and 3 are not needed. For more information, see Option 1: Set up SSL for Elastic using a self-generated certificate authority (CA).
    • Enter 2 to convert certificates that have been added to the Keys folder. The certificate must be a PFX with a SAN name with an exportable key. The associated CER files for the TLS chain must also be present in the Keys folder. For more information, see Option 2: Convert certificates from CER and PFX format to PEM and Key.
    • Enter 3 after using Option 2 to use the converted certificates. This option can be used as a standalone option if the PEM and KEY files have already been placed into the DataGridCerts folder in the tool as follows:
      • Add PEM files for each level of the TLS chain to the TLSChain folder
      • Add the PEM file for the node certificate to the NodeCertificate folder
      • Add the Key folder for the node certificate to the NodeKey folder

      For more information, see Option 3: Set up SSL for Elastic using an externally generated TLS chain.

Option 1: Set up SSL for Elastic using a self-generated certificate authority (CA)

If you selected Option 1, continue as follows in PowerShell:

  1. Enter a password for the Certificate Authority, and then hit Enter.

    Note: Use a long complex alpha numeric password, and avoid using special characters.

  2. Enter a password for the node’s certificate, and then hit Enter.

    Note: Use a long complex alpha numeric password, and avoid using special characters.

    The script creates a CA file in the \RelativityDataGrid\elasticsearch-main\bin directory. This completes the installation on the first node.

  3. Copy the CA file to the \RelativityDataGrid\elasticsearch-main\bin directory for all other nodes in the cluster.
  4. Run the script on all other nodes in the cluster choosing Option 1.

Option 2: Convert certificates from CER and PFX format to PEM and Key

If you select Option 2, your node’s pfx file and the root and intermediate certificates are converted to PEM and Key format. The pfx certificate must have a subject alternative name and a password for the workflow to be successful:

  1. Copy the pfx for the node into the Key folder. Create a CER file for all intermediate certificates and the root CA associated with the pfx file.
  2. In Powershell, enter 2, and then hit Enter.
  3. Enter the password for the pfx file. The script converts the pfx file and the CER files to PEM and Key format in the DataGridCerts folder.
  4. Enter 3, and then hit Enter. Continue below.

Option 3: Set up SSL for Elastic using an externally generated TLS chain

After you select Option 3, the script asks to copy the PEM and key files to the appropriate folders. Continue as follows: 

  1. If option 2 is completed, hit Enter. Otherwise, manually copy the files to the appropriate folders, and then hit Enter.
  2. Enter the password for the node's certificate.

Option 4: Exit

Exits the script.