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.
- Helm
- Docker
redis:
external:
enabled: true
connectionUrl: "Your connection url"
# In your .env file
REDIS_DATABASE_URI="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.