cargo-shuttle
brings shuttle, the open source serverless platform for Rust web applications, into your terminal. With a dedicated focus on productivity, reliability, and performance, cargo-shuttle
makes deploying your code to the cloud as easy as deriving a trait.
cargo-shuttle
is available for macOS, Linux, and Windows. To install the commandline tool, run:
sh
$ cargo install cargo-shuttle
cargo-shuttle
's subcommands help you build and deploy web apps from start to finish.
Run cargo-shuttle --help
to see the basic usage:
```
USAGE:
cargo-shuttle [OPTIONS]
OPTIONS:
--api-url
SUBCOMMANDS: auth create user credentials for the shuttle platform delete delete this shuttle service deploy deploy a shuttle service deployment manage deployments of a shuttle service help Print this message or the help of the given subcommand(s) init create a new shuttle service login login to the shuttle platform logs view the logs of a deployment in this shuttle service run run a shuttle service locally status view the status of a shuttle service ```
init
To initialize a shuttle project with boilerplates, run cargo shuttle init [OPTIONS] [PATH]
.
Currently, cargo shuttle init
supports the following frameworks:
--axum
: for axum framework--poem
: for poem framework--rocket
: for rocket framework--tide
: for tide framework--tower
: for tower libraryFor example, running the following command will initialize a project for rocket:
sh
$ cargo shuttle init --rocket my-rocket-app
This should generate the following dependency in Cargo.toml
:
toml
shuttle-service = { version = "0.8.0", features = ["web-rocket"] }
The following boilerplate code should be generated into src/lib.rs
:
```rust
extern crate rocket;
use shuttle_service::ShuttleRocket;
fn hello() -> &'static str { "Hello, world!" }
async fn init() -> ShuttleRocket { let rocket = rocket::build().mount("/", routes![hello]);
Ok(rocket)
} ```
run
To run the shuttle project locally, use the following command:
```sh
$ cargo shuttle run ```
This will compile your shuttle project and start it on the default port 8000
. Test it by:
sh
$ curl http://localhost:8000/hello
Hello, world!
login
Use cargo shuttle login
inside your shuttle project to generate an API key for the shuttle platform:
```sh
$ cargo shuttle login ```
This should automatically open a browser window with an auto-generated API key for your project. Simply copy-paste the API key back in your terminal or run the following command to complete login:
sh
$ cargo shuttle login --api-key your-api-key-from-browser
deploy
To deploy your shuttle project to the cloud, run:
sh
$ cargo shuttle project new
$ cargo shuttle deploy
Your service will immediately be available at {crate_name}.shuttleapp.rs
. For instance:
sh
$ curl https://my-rocket-app.shuttleapp.rs/hello
Hello, world!
status
Check the status of your deployed shuttle project with:
sh
$ cargo shuttle status
logs
Check the logs of your deployed shuttle project with:
sh
$ cargo shuttle logs
auth
Run the following to create user credentials for shuttle platform:
sh
$ cargo shuttle auth your-desired-username
delete
Once you are done with a deployment, you can delete it by running:
sh
$ cargo shuttle delete
Thanks for using cargo-shuttle
! Weβre very happy to have you with us!
During our alpha period, API keys are completely free and you can deploy as many services as you want.
Just keep in mind that there may be some kinks that require us to take all deployments down once in a while. In certain circumstances we may also have to delete all the data associated with those deployments.
To contribute to cargo-shuttle
or stay updated with our development, please open an issue, discussion or PR on Github and join our Discord! π