Deploy to Fly using a Depot builder
Have you ever been playing Rock, Paper, Scissors against an API endpoint and thought to yourself, wow, I wish this would load faster in Australia? No, of course not, but you have more interesting services and apps than Rock, Paper, Scissors.
Yet, that is what we are going to do today, and we are going to do it fast, from quick builds to low latency deployments.
You may already know, Fly.io is a cloud platform that makes it easy to deploy globally distributed applications with zero config load balancing. Fly runs your code close to the user for minimal latency. Supply your code, optionally provide a Dockerfile, and Fly will take care of the rest.
Part of deploying an application fast, is building it fast. We recently announced our partnership with Fly.io🎉, and now Fly users can immediately take advantage of Depot's accelerated Docker builders to build and deploy their applications faster than ever, no Depot account required.
In this quick walkthrough, I'll show you how to build and deploy a TypeScript service to Fly.io using the new Depot builder.
Why build with Depot on Fly?
Depot builds faster. Over the past two years, Depot has developed and optimized a custom build engine based on Docker’s BuildKit, excelling in the cloud. Depot automatically manages distributed build caches with perfectly incremental builds, so you can build your Docker images in seconds, not minutes.
When paired with Fly's blazing-fast Firecracker VM based infrastructure, Depot and Fly provide a powerful combination for building and deploying your applications globally with speed.
Sample Project Setup
Clone or download our sample app from the GitHub repository. Inside you'll find a simple NestJS TypeScript API service. It has a single endpoint for playing Rock, Paper, Scissors, and a Swagger UI for testing and documentation
The Dockerfile
Notice, we have a Dockerfile in the root of the project. This Dockerfile is designed to build an optimized Docker image for our TypeScript service, taking advantage of multi-stage builds and optimized caching. We have a great full-detailed guide on how to write an optimized Dockerfile for Node with pnpm here. Using Fly, it isn't required that you provide a Dockerfile, but we can often craft a more optimized build process when you do.
Let's take a quick look at our Dockerfile
Based on our Node pnpm Dockerfile guide mentioned above, our Dockerfile is organized into three stages.
We start with an optimized base image, like node:lts-alpine
to minimize additional files in the image layers, reducing the final size of the built image. The default node
image based on Debian is 1.09GB
vs node:lts-alpine
at 132MB
.
From our base image, we create a series of stages to optimize the build process for further enhancing the cache ability of the build layers.
Local Testing
Before deploying to Fly, let's test our service locally and explore the Swagger UI, so we know what to expect when we deploy it.
We're going to build the Dockerfile. If you have a Depot account you can use the depot build
command to take advantage of our powerful remote builders, otherwise you can use docker build
.
Now we can run the Docker container and test the service.
Hello World!
Open up your browser and navigate to http://localhost:3000/ and verify you see a Hello World!
message.
Swagger UI
The Swagger UI is available at http://localhost:3000/api. Here you can see documentation about the available endpoints in the service and even test them out with a nice UI.
Try hitting the "Test it out" button and then "Execute" to play a game of Rock, Paper, Scissors with your selected "Move".
Example response:
Deploy to Fly
Now that we have confirmed the service is working as expected, let's deploy it to Fly using the new Depot builder.
The project already comes with a pre-defined fly.toml
. You can use or edit what is included, or delete it and run fly launch
to generate a new config file pointing to your local region and select an app name automatically.
If you use the included fly.toml
, make sure to replace <app-name>
with a unique name for your service.
Use the --depot
flag to specify the Depot builder should be used to accelerate the build process.
Behind the scenes, Depot is running accelerated container image builders with instant caching across builds inside of Fly. You can watch the build logs in your terminal as the service is built and deployed. On your first deployment you likely Depot builds and caches the initial layers, and subsequent builds automatically reuse previous layers that are valid in your Docker layer cache.
Once the build is complete, you'll see a message with the URL to access your service.
Go ahead and open the URL in your browser to /api
and you should see the Swagger UI for the Rock, Paper, Scissors service.
Try Depot on Fly
Congratulations 🎉! You've successfully deployed a TypeScript service to Fly using the new Depot builder. We'd love to know how it went! For Fly-specific questions, check out the announcement post on the Fly.io forum.
Have a question about Depot? Let's chat on Discord! Join us in the Depot Discord server and let us know how we can help you build and deploy faster.