Awesome
<!-- markdownlint-disable --> <p align="center"> <img width="300" src="https://raw.githubusercontent.com/shuttle-hq/shuttle/master/assets/logo-rectangle-transparent.png"/> </p> <br> <p align="center"> <a href="https://github.com/shuttle-hq/shuttle/search?l=rust"> <img alt="language" src="https://img.shields.io/badge/language-Rust-orange.svg"> </a> <a href="https://docs.shuttle.rs/"> <img alt="docs" src="https://img.shields.io/badge/docs-shuttle.rs-orange"> </a> <a href="https://docs.rs/shuttle-runtime"> <img alt="crate-docs" src="https://img.shields.io/badge/docs-docs.rs-orange"> </a> <a href="https://status.shuttle.rs/"> <img alt="status" src="https://img.shields.io/badge/status-blue"> </a> <a href="https://circleci.com/gh/shuttle-hq/shuttle/"> <img alt="build status" src="https://circleci.com/gh/shuttle-hq/shuttle.svg?style=shield"/> </a> </p> <p align="center"> <a href="https://crates.io/crates/cargo-shuttle"> <img alt="crates" src="https://img.shields.io/crates/d/cargo-shuttle"> </a> <a href="https://discord.gg/shuttle"> <img alt="discord" src="https://img.shields.io/discord/803236282088161321?logo=discord"/> </a> <a href="https://twitter.com/shuttle_dev"> <img alt="Twitter Follow" src="https://img.shields.io/twitter/follow/shuttle_dev"> </a> </p> <p align="center"> <a href="https://console.algora.io/org/shuttle/bounties?status=open"> <img alt="open bounties" src="https://img.shields.io/endpoint?url=https%3A%2F%2Fconsole.algora.io%2Fapi%2Fshields%2Fshuttle%2Fbounties%3Fstatus%3Dopen"/> </a> <a href="https://console.algora.io/org/shuttle/bounties?status=completed"> <img alt="rewarded bounties" src="https://img.shields.io/endpoint?url=https%3A%2F%2Fconsole.algora.io%2Fapi%2Fshields%2Fshuttle%2Fbounties%3Fstatus%3Dcompleted"/> </a> </p> <br> <h1 align="center">Fastest Way to Build & Ship Rust Apps</h1> <div align="center"> Get resources and deploy your apps with a few lines of code. </div> <h3 align="center">Simple. Easy. Joyful.</h3> <p align="center"> <a href="https://github.com/shuttle-hq/shuttle/issues/new?assignees=&labels=S-Triage%2CT-Bug&projects=&template=BUG-REPORT.yml&title=%5BBug%5D%3A+">Report Bug</a> ยท <a href="https://github.com/shuttle-hq/shuttle/issues/new?assignees=&labels=S-Triage%2CT-Feature+Request&projects=&template=FEATURE-SUGGESTION.yml&title=%5BFeature%5D%3A+">Request a Feature</a> ยท <a href="https://discord.gg/shuttle">Join Our Discord</a> ยท <a href="https://twitter.com/shuttle_dev">Follow us on Twitter</a> </p> <div align="center"><img src="https://i.imgur.com/1qdWipP.gif" width="100%" ></div> <br><div align="center">โญ If you find Shuttle interesting, consider starring this repo to help spread the word.</div> <br>
Features
- One-line Resource Provisioning: Get a database, or any other AWS resource by adding a line of code to your main file. To delete one, just remove that line of code. No config/yaml files required.
- Rapid Development: It takes 2 minutes from project initialization to a deployed project. It takes another 2 minutes to provision a resource, and get it deployed to production.
- First-class support for popular Rust frameworks: Axum, Actix Web, Rocket, and more
- Security: Let us worry about the security & permissions while you focus on writing good code. <br>
Quick Start
On Linux and macOS, you can use this install script, which will automatically install the correct target for your OS and distro:
curl -sSfL https://www.shuttle.rs/install | bash
On Windows, you can use this install script to do the same:
iwr "https://www.shuttle.rs/install-win" | iex
After installing, log in with:
shuttle login
To initialize your project, simply write:
shuttle init --template axum hello-world
And to deploy it, write:
cd hello-world
shuttle deploy
And... that's it!
Service Name: hello-world
Deployment ID: 3d08ac34-ad63-41c1-836b-99afdc90af9f
Status: running
Last Updated: 2022-04-01T08:32:34Z
URI: https://hello-world.shuttleapp.rs
Feel free to build on top of the generated hello-world
boilerplate or take a stab at one of our examples.
For the full documentation, visit our docs. <br> <br>
Quick Look
Below is a basic "Hello World" application written in Axum:
use axum::{routing::get, Router};
#[tokio::main]
async fn main() {
let app = Router::new().route("/", get(hello_world));
let listener = tokio::net::TcpListener::bind("127.0.0.1:3000")
.await
.unwrap();
println!("listening on {}", listener.local_addr().unwrap());
axum::serve(listener, app).await.unwrap();
}
async fn hello_world() -> &'static str {
"Hello, world!"
}
In order to be able to deploy it with a single command, we update the snippet as follows:
use axum::{routing::get, Router};
async fn hello_world() -> &'static str {
"Hello, world!"
}
#[shuttle_runtime::main]
async fn main() -> shuttle_axum::ShuttleAxum {
let router = Router::new().route("/", get(hello_world));
Ok(router.into())
}
Now, with just shuttle deploy
, you can see your application live. But let's enhance it further by adding a shared Postgres database:
use axum::{routing::get, Router};
async fn hello_world() -> &'static str {
"Hello, world!"
}
#[shuttle_runtime::main]
async fn main(
#[shuttle_shared_db::Postgres] pool: sqlx::PgPool,
) -> shuttle_axum::ShuttleAxum {
pool.execute(include_str!("../schema.sql"))
.await
.expect("failed to run migrations");
let router = Router::new().route("/", get(hello_world));
Ok(router.into())
}
Now, if we run shuttle deploy
, we'll have an up and running project with a database inside & ready to use.
<br>
<br>
Repositories
Name | Description |
---|---|
shuttle ๐ (This repo) | The core Shuttle product. Contains all crates that users interact with. |
shuttle-examples ๐จโ๐ซ | Officially maintained examples of projects that can be deployed on Shuttle. Also has a list of community examples. |
shuttle-docs ๐ | Documentation hosted on docs.shuttle.rs. |
www ๐ | Our website shuttle.rs, including the blog and Launchpad newsletter. |
deploy-action โ | GitHub Action for continuous deployments. |
awesome-shuttle ๐ | An awesome list of Shuttle-hosted projects and resources that users can add to. |
shuttlings โ๏ธ | A collection of Rust code challenges. A great way to get started with using Rust and Shuttle. |
Contributing to Shuttle
Contributing to Shuttle is highly encouraged! Even if you are not planning to submit any code, joining our Discord server and providing feedback helps us a lot!
Check out our contributing docs and find the appropriate repo above to contribute to. For development of this repo, check the development docs.
Algora Bounties ๐ฐ
To offload work from the engineering team on low-priority issues, we will sometimes add a cash bounty to issues. Sign up to the Algora Console to find open issues with bounties.
Project Status
Check for any outages and incidents on Shuttle Status.
We are currently in Public Beta. Watch "releases" of this repo to get notified of major updates! Also, check out the Beta announcement for features we are looking forward to.
- Alpha: We are testing Shuttle, API and deployments may be unstable
- Public Alpha: Anyone can sign up, but go easy on us, there are a few kinks
- Public Beta: Stable enough for most non-enterprise use-cases
- Public: Production-ready! <br>
Contributors โจ
Thanks goes to these wonderful people:
<!-- markdownlint-disable --> <a href="https://github.com/shuttle-hq/shuttle/graphs/contributors"> <img src="https://contrib.rocks/image?repo=shuttle-hq/shuttle" /> </a>Made with contrib.rocks.