Fly.io
Deploy your RAG application to fly.io platform
Embedchain has a nice and simple abstraction on top of the Fly.io tools to let developers deploy RAG application to fly.io platform seamlessly.
Follow the instructions given below to deploy your first application quickly:
Step-1: Install flyctl command line
Once you have installed the fly.io cli tool, signup/login to their platform using the following command:
In case you run into issues, refer to official fly.io docs.
Step-2: Create RAG app
We provide a command line utility called ec
in embedchain that inherits the template for fly.io
platform and help you deploy the app. Follow the instructions to create a fly.io app using the template provided:
pip install embedchain
mkdir my-rag-app
ec create --template=fly.io
This will generate a directory structure like this:
โโโ Dockerfile
โโโ app.py
โโโ fly.toml
โโโ .env
โโโ .env.example
โโโ embedchain.json
โโโ requirements.txt
Feel free to edit the files as required.
Dockerfile
: Defines the steps to setup the applicationapp.py
: Contains API app codefly.toml
: fly.io config file.env
: Contains environment variables for production.env.example
: Contains dummy environment variables (can ignore this file)embedchain.json
: Contains embedchain specific configuration for deployment (you donโt need to configure this)requirements.txt
: Contains python dependencies for your application
Step-3: Test app locally
You can run the app locally by simply doing:
pip install -r requirements.txt
ec dev
Step-4: Deploy to fly.io
You can deploy to fly.io using the following command:
ec deploy
Once this step finished, it will provide you with the deployment endpoint where you can access the app live. It will look something like this (Swagger docs):
You can also check the logs, monitor app status etc on their dashboard by running command fly dashboard
.
Seeking help?
If you run into issues with deployment, please feel free to reach out to us via any of the following methods: