15 releases
new 0.0.16 | Dec 13, 2024 |
---|---|
0.0.15 | Dec 9, 2024 |
0.0.14 | Nov 17, 2024 |
0.0.10 | Oct 17, 2024 |
0.0.8 | Sep 24, 2024 |
#107 in Development tools
520 downloads per month
255KB
6K
SLoC
Rush README
Overview
Rush
(Rush Deployment) is a Rust-based deployment tool that aims to bridge the gap between development and production environments by allowing cross-compilation of x86
Docker images on arm64
platforms, such as Apple Silicon. This ensures developers can build and deploy x86
images from Apple Silicon without the need for separate environments. It also simplifies managing multiple products in a single repository and running multiple containers locally for development with ingress routing traffic.
Key Features
- Cross-compilation: Automatically cross-compiles Docker images to the target architecture (e.g.,
x86
on Apple Silicon). - Fast builds: Efficient cross-compiling speeds up Docker image building.
- Multi-container support: Easily run multiple containers locally, complete with ingress routing.
- Multi-product management: Simplifies the handling of multiple products within a monorepo structure.
- Multi-environment support: Supports different environments (
local
,dev
,staging
andprod
) with separate configurations and secrets. - Secret management: Manages secrets for local development and deployment. Supports 1Password and Kubeseal out of the box.
Demo
Installation
Prerequisites
Before installing rush
, ensure that you have the following prerequisites installed:
-
Rust via
rustup
:curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
-
Trunk (for frontend builds):
- Install the WebAssembly (WASM) target:
rustup target add wasm32-unknown-unknown
- Install
trunk
:cargo install trunk
- (Optional) Rename
trunk
to avoid conflicts with other CI tools:pushd $HOME/.cargo/bin mv trunk wasm-trunk popd
- Install the WebAssembly (WASM) target:
-
Docker and buildx: Ensure that Docker and Docker Buildx are installed for cross-compilation.
-
Toolchains (Apple Silicon): For Apple Silicon users, cross-compilation requires installing the
x86_64
toolchain and Rust targets:arch -arm64 brew install SergioBenitez/osxct/x86_64-unknown-linux-gnu rustup target add x86_64-unknown-linux-gnu
Installing rush
To install rush
, run the following command:
cargo install rush-cli
Make sure that the cargo binary directory is in your PATH
:
source $HOME/.cargo/env
If you have already installed rush
, you can update it by running the installation command again.
Quick Start
Running a Simple Example
Once you’ve followed the installation steps, you can test rush
with one of its examples. From anywhere within the cloned repository, run:
rush helloworld.wonop.io dev
This will start the development server for the helloworld.wonop.io
example.
Local Development Setup
-
Initialize Secrets: Initialize the required secrets for your local environment:
rush helloworld.wonop.io secrets init
This will generate
.env
files containing environment variables and secrets necessary for running your platform locally. For PostgreSQL and Redis, use the following connection strings:- PostgreSQL:
postgres://admin:admin@localhost:5433/backend
- Redis:
redis://localhost:6379
- PostgreSQL:
-
Start the Development Server: Once the secrets and environment variables are set, start the development server:
rush helloworld.wonop.io dev
The application will be available at
http://localhost:9000
.
Kubernetes Deployment
For deploying to a Kubernetes cluster, rush
provides seamless integration. Follow these steps for configuring secrets and setting up the environment:
-
Initialize Secrets for Staging: Run the following command to configure secrets for the staging environment:
rush --env staging helloworld.wonop.io secrets init
-
Enter Database and Redis URLs: During the initialization, you’ll be prompted to enter the database and Redis URLs:
- Example database URL:
postgres://[user]:[password]@[host]:[port]/[database_name]
- Example Redis URL:
rediss://[user]:[password]@[host]:[port]
- Example database URL:
-
Deploying to Kubernetes: Assuming you have a Kubernetes cluster and
kubectl
configured, along with contexts and Docker registry configured inrushd.yaml
, you can deploy the application with:rush --env staging helloworld.wonop.io deploy
Cross-Compilation on Apple Silicon
For Apple Silicon users, rush
cross-compiles x86
images for deployment onto x86
Kubernetes clusters. Ensure that you have the x86_64
toolchain and Docker Buildx configured. Follow these steps:
-
Install the necessary toolchain:
arch -arm64 brew install SergioBenitez/osxct/x86_64-unknown-linux-gnu
-
Add the
x86_64
target for Rust:rustup target add x86_64-unknown-linux-gnu
rush
will automatically handle cross-compiling Docker images into x86
format, making them compatible with your production environment.
Advanced Usage
Managing Multiple Products in a Monorepo
rush
is designed to handle multiple products within a single repository. You can create a new product by simply structuring your directory as follows:
/products
/io.wonop.helloworld
/io.wonop.app
/io.wonop.api
Running rush
from the repository root will manage all products simultaneously. This simplifies development workflows when working with large, multi-product projects.
Dependencies
~26–40MB
~647K SLoC