Deploy Letta Server on Railway
Deploying the Letta Railway template
We’ve prepared a Letta Railway template that has the necessary environment variables set and mounts a persistent volume for database storage. You can access the template by clicking the “Deploy on Railway” button below:
data:image/s3,"s3://crabby-images/2d350/2d3507d4e48c713b78820989ea01c787ae72b0ab" alt=""
data:image/s3,"s3://crabby-images/d0e3b/d0e3bd52b5d6d66fa652bf6e8ceee2e843003cfa" alt=""
data:image/s3,"s3://crabby-images/8e45e/8e45e83b36aeb1b19832771329e0a6f1b5fc79f7" alt=""
Accessing the deployment via the ADE
Now that the Railway deployment is active, all we need to do to access it via the ADE is add it to as a new remote Letta server.
The default password set in the template is password
, which can be changed at the deployment stage or afterwards in the ‘variables’ page on the Railway deployment.
Click “Add remote server”, then enter the details from Railway (use the static IP address shown in the logs, and use the password set via the environment variables):
data:image/s3,"s3://crabby-images/691d1/691d16ec56e03d6059460c3a09ad3299d80885d3" alt=""
data:image/s3,"s3://crabby-images/18f9f/18f9f47301ed840596dbea6c6ba4bdb8d01b0fab" alt=""
Accessing the deployment via the Letta API
Accessing the deployment via the Letta API is simple, we just need to swap the base URL of the endpoint with the IP address from the Railway deployment.
For example if the Railway IP address is https://MYSERVER.up.railway.app
and the password is banana
, to create an agent on the deployment, we can use the following shell command:
This will create an agent with two memory blocks, configured to use gpt-4o-mini
as the LLM model, and text-embedding-3-small
as the embedding model. We also include the base Letta tools in the request.
If the Letta server is not password protected, we can omit the X-BARE-PASSWORD
header.
Adding additional environment variables
To help you get started, when you deploy the template you have the option to fill in the example environment variables OPENAI_API_KEY
(to connect your Letta agents to GPT models), ANTHROPIC_API_KEY
(to connect your Letta agents to Claude models), and COMPOSIO_API_KEY
(to connect your Letta agents to Composio’s library of over 7k pre-made tools).
There are many more providers you can enable on the Letta server via additional environment variables (for example vLLM, Ollama, etc). For more information on available providers, see our documentation.
To connect Letta to an additional API provider, you can go to your Railway deployment (after you’ve deployed the template), click Variables
to see the current environment variables, then click + New Variable
to add a new variable. Once you’ve saved a new variable, you will need to restart the server for the changes to take effect.