Environment
R2R Troubleshooting Guide: Missing Environment Variables
When deploying R2R, missing environment variables can cause containers to fail to start or lead to unexpected behavior. This guide will help you identify and resolve issues related to missing environment variables.
1. Identifying the Problem
Signs that you might be dealing with missing environment variables:
- Containers exit immediately after starting
- Error messages in logs mentioning undefined or null values
- Specific features or integrations not working as expected
2. Common Missing Environment Variables
Here are some critical environment variables for R2R:
- Database credentials (e.g.,
POSTGRES_USER
,POSTGRES_PASSWORD
) - API keys (e.g.,
OPENAI_API_KEY
,ANTHROPIC_API_KEY
) - Configuration settings (e.g.,
CONFIG_NAME
,CONFIG_PATH
)
3. Checking for Missing Variables
3.1 Review Docker Compose File
- Open your
docker-compose.yml
file. - Look for the
environment
section under ther2r
service. - Ensure all required variables are listed.
Example:
3.2 Check .env File
- Ensure you have a
.env
file in the same directory as yourdocker-compose.yml
. - Verify that all variables used in
docker-compose.yml
are defined in.env
.
Example .env
file:
3.3 Verify Environment in Running Container
If the container starts but behaves unexpectedly:
- Access the container’s shell:
- Check environment variables:
4. Resolving Missing Variables
4.1 Update .env File
- Add any missing variables to your
.env
file. - Ensure values are correct and properly formatted.
4.2 Use Default Values
In docker-compose.yml
, provide default values for non-sensitive variables:
4.3 Inject Variables at Runtime
For sensitive data, inject variables when running the container:
Or with docker-compose:
4.4 Use Docker Secrets
For enhanced security, consider using Docker secrets for sensitive data:
-
Create a secret:
-
Use in
docker-compose.yml
:
5. Specific R2R Environment Variables
Ensure these key R2R variables are set:
CONFIG_NAME
orCONFIG_PATH
: Specifies which configuration to use.POSTGRES_*
: Database connection details.OPENAI_API_KEY
: If using OpenAI services.ANTHROPIC_API_KEY
: If using Anthropic models.OLLAMA_API_BASE
: For local LLM integration.HATCHET_CLIENT_TOKEN
: For Hatchet integration.
6. Debugging Tips
- Use
docker-compose config
to see the final composed configuration with resolved variables. - Temporarily echo sensitive variables in your container’s entrypoint script for debugging (remove in production).
- Check for typos in variable names both in
docker-compose.yml
and.env
files.
7. Best Practices
- Use version control for your
docker-compose.yml
, but not for.env
files containing secrets. - Consider using a secret management service for production deployments.
- Document all required environment variables in your project’s README.
- Use CI/CD pipelines to validate the presence of required variables before deployment.
By following this guide, you should be able to identify and resolve issues related to missing environment variables in your R2R deployment. Remember to always handle sensitive data securely and never commit secrets to version control.