Skip to main content

Connect to an External Redis Database

LangSmith uses Redis to back our queuing/caching operations. By default, LangSmith Self-Hosted will use an internal Redis instance. However, you can configure LangSmith to use an external Redis instance (strongly recommended in a production setting). By configuring an external Redis instance, you can more easily manage backups, scaling, and other operational tasks for your Redis instance.

Requirements

  • A provisioned Redis instance that your LangSmith instance will have network access to. We recommend using a managed Redis service like:
  • Note: We do only officially support Redis versions >= 5.
  • We only officially support Redis in a non-clustered configuration. We do not support Redis Cluster(certain tiers of managed Redis services may use Redis Cluster under the hood, but you can point to a single node in the cluster).

Connection String

We use redis-py to connect to Redis. This library supports a variety of connection strings. You can find more information on the connection string format here.

You will need to assemble the connection string for your Redis instance. This connection string should include the following information:

  • Host
  • Database
  • Port
  • URL params

This will take the form of:

"redis://host/db:port?<url_params>"

An example connection string might look like:

"redis://langsmith-redis:6379/0"

To use SSL, you can use the rediss:// prefix. An example connection string with SSL might look like:

"rediss://langsmith-redis:6380/0?password=foo"

Configuration

With your connection string in hand, you can configure your LangSmith instance to use an external Redis instance. You can do this by modifying the values file for your LangSmith Helm Chart installation or the .env file for your Docker installation.


redis:
external:
enabled: true
connectionUrl: "Your connection url"

Once configured, you should be able to reinstall your LangSmith instance. If everything is configured correctly, your LangSmith instance should now be using your external Redis instance.


Was this page helpful?


You can leave detailed feedback on GitHub.