Internode encryption

Describes internode encryption which improves the security of data in transit.

As of v6.2.4, Redis Enterprise Software supports internode encryption, which encrypts internal communication between nodes. This improves the security of data as it travels within a cluster.

Internode encryption is enabled for the control plane, which manages the cluster and its databases.

Internode encryption is supported for the data plane, which encrypts communication used to replicate shards between nodes and proxy communication with shards located on different nodes.

The following diagram shows how this works.

A diagram showing the interaction between data internode encryption, control plane encryption, and various elements of a cluster.

Data internode encryption is disabled by default for individual databases in order to optimize for performance. Encryption adds latency and overhead; the impact is measurable and varies according to the database, its field types, and the details of the underlying use case.

You can enable data internode encryption for a database by changing the database configuration settings. This lets you choose when to favor performance and when to encrypt data.

Prerequisites

Internode encryption requires certain prerequisites.

You need to:

  • Upgrade all nodes in the cluster to v6.2.4 or later.

  • Open port 3342 for the TLS channel used for encrypted communication.

Enable data internode encryption

To enable internode encryption for a database (also called data internode encryption), you need to enable the appropriate setting for each database you wish to encrypt. To do so, you can:

  • Use the admin console to enable the Internode Encryption setting from the database Security screen.

  • Use the rladmin command-line utility to set the data_internode_encryption setting for the database:

    rladmin tune db <database_id> data_internode_encryption enabled
    
  • Use the Redis Enterprise Software REST API to set the data_internode_encryption setting for the database.

    put /v1/bdbs/${database_id}
    { “data_internode_encryption” : true }
    

When you change the data internode encryption setting for a database, all active remote client connections are disconnected. This restarts the internal (DMC) proxy and disconnects all client connections.

Change cluster policy

To enable internode encryption for new databases by default, use one of the following methods:

  • Cluster Manager UI

    1. On the Databases screen, select Toggle actions button to open a list of additional actions.

    2. Select Database defaults.

    3. Go to Internode Encryption and click Change.

    4. Select Enabled to enable internode encryption for new databases by default.

    5. Click Change.

    6. Select Save.

  • rladmin tune cluster:

    rladmin tune cluster data_internode_encryption enabled
    
  • Update cluster policy REST API request:

    PUT /v1/cluster/policy 
    { "data_internode_encryption": true }
    

Encryption ciphers and settings

To encrypt internode communications, Redis Enterprise Software uses TLS 1.2 and the following cipher suites:

  • ECDHE-RSA-AES256-GCM-SHA384
  • ECDHE-RSA-AES128-GCM-SHA256

As of Redis Enterprise Software v7.4, internode encryption also supports TLS 1.3 with the following cipher suites:

  • TLS_AES_128_GCM_SHA256
  • TLS_AES_256_GCM_SHA384

The TLS layer determines which TLS version to use.

No configurable settings are exposed; internode encryption is used internally within a cluster and not exposed to any outside service.

Certificate authority and rotation

Starting with v6.2.4, internode communication is managed, in part, by two certificates: one for the control plane and one for the data plane. These certificates are signed by a private certificate authority (CA). The CA is not exposed outside of the cluster, so it cannot be accessed by external processes or services. In addition, each cluster generates a unique CA that is not used anywhere else.

The private CA is generated when a cluster is created or upgraded to 6.2.4.

When nodes join the cluster, the cluster CA is used to generate certificates for the new node, one for each plane. Certificates signed by the private CA are not shared between clusters and they're not exposed outside the cluster.

All certificates signed by the internal CA expire after ninety (90) days and automatically rotate every thirty (30) days. Alerts also monitor certificate expiration and trigger when certificate expiration falls below 45 days. If you receive such an alert, contact support.

You can use the Redis Enterprise Software REST API to rotate certificates manually:

POST /v1/cluster/certificates/rotate
RATE THIS PAGE
Back to top ↑