Search documentation...

K
ChangelogBook a demoSign up

Redis

Redis is an in-memory data structure store, used as a distributed, in-memory key–value database, cache and message broker, with optional durability. Redis supports different kinds of abstract data structures, such as strings, lists, maps, sets, etc.

Supported syncing

Sync TypeDescriptionSupported Sync ModesAPI Reference
Redis CacheSync data from any source to a Redis cache databaseUpsert, UpdateRedis Cache

Connect to Redis

Go to the Destinations overview page and click the Add destination button. Select Redis and click Continue. You can then authenticate Hightouch to Redis with your hostname and port. If your Redis instance has authentication credentials, you can also input a username and password.

Connecting to a Redis cluster requires additional configuration

SSH tunneling

Hightouch can connect directly to Redis over the public internet or via an SSH tunnel. Since data is encrypted in transit via TLS, a direct connection is suitable for most use cases. You may need to set up a tunnel if your Redis instance is on a private network or virtual private cloud (VPC).

Hightouch supports both standard and reverse SSH tunnels. To learn more about SSH tunneling, refer to Hightouch's tunneling documentation.

Sync configuration

Once you've set up your Redis destination and have a model to pull data from, you can set up your sync configuration to begin syncing data. Go to the Syncs overview page and click the Add sync button to begin. Then, select the relevant model and the Redis destination you want to sync to.

Syncing to a cache database

Hightouch supports syncing keys and members to Redis.

Syncing keys

Keys identify, store, and retrieve data. Each key in Redis maps to a corresponding value.

Supported commands

CommandDescriptionSupported Sync ModesAPI Reference
SETSet key to hold the string value.Upsert, UpdateSET Command
HSETSet specified fields to their respective values in the hash stored at key.Upsert, UpdateHSET Command
SADDAdd specified members to the set stored at key.UpsertSADD Command
GEOADDAdd specified geospatial items (longitude, latitude, name) to the specified key.UpsertGEOADD Command

Record matching

To match rows from your model to records in Redis, you need to select the model column that contains values that match the Key field in Redis.

Field mapping

You can sync columns from your source to custom fields in Redis.

Time to live (TTL)

You can set an expiration for the keys that you are syncing to Redis by setting a TTL value. This value is the amount of time in seconds that the keys will exist in Redis before they're automatically deleted.

Delete behavior

The delete behavior you select dictates what to do when a row no longer appears in your model's query results. You have the following options:

BehaviorDescription
Do nothingKeep the key in Redis with its fields untouched
ClearKeep the key in Redis, but set mapped fields to empty
DeleteRemove the key from Redis

Syncing members

Members are used for managing sorted sets in Redis.

Supported commands

CommandDescriptionSupported Sync ModesAPI Reference
ZADDAdd all specified members with the specified scores to the sorted set stored at key.Upsert, UpdateZADD Command
GEOADDAdd specified geospatial items (longitude, latitude, name) to the specified key.UpsertGEOADD Command

Record matching

To match rows from your model to records in Redis, select the model column that contains the unique member values of each element of the sorted set in Redis.

Field mapping

The fields available for mapping depend on the command that you've selected.

Delete behavior

The delete behavior you select dictates what to do when a row no longer appears in your model's query results. You have the following options:

BehaviorDescription
Do nothingKeep the member in Redis with its fields untouched
ClearKeep the member in Redis, but set mapped fields to empty
DeleteRemove the member from the sorted set from Redis

Redis Cluster

Redis Cluster does not support the transactions we use to power this integration by default. In order to run a sync to Redis Cluster transactions must be turned off at the bottom of the sync config:

Disabling transactions in Hightouch

Tips and troubleshooting

Common errors

If you encounter an error or question not listed below and need assistance, don't hesitate to . We're here to help.

Invalid argument type

This error can happen when syncing data types that aren't supported by Redis, such as null values. If your model columns contain null values, you can enable Don't sync null values to avoid syncing them.

Live debugger

Hightouch provides complete visibility into the API calls made during each of your sync runs. We recommend reading our article on debugging tips and tricks to learn more.

Sync alerts

Hightouch can alert you of sync issues via Slack, PagerDuty, SMS, or email. For details, please visit our article on alerting.

Ready to get started?

Jump right in or a book a demo. Your first destination is always free.

Book a demoSign upBook a demo

Need help?

Our team is relentlessly focused on your success. Don't hesitate to reach out!

Feature requests?

We'd love to hear your suggestions for integrations and other features.

Last updated: Jul 3, 2024

On this page

Supported syncingConnect to RedisSSH tunnelingSync configurationSyncing to a cache databaseSyncing keysSyncing membersRedis ClusterTips and troubleshootingCommon errorsLive debuggerSync alerts

Was this page helpful?