#docker-image #docker #docker-build #cross-compilation #apple-silicon #kubernetes #axum

app rush-cli

Rush Deployment: A tool to bring the development experience as close to the production experience as possible

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

Download history 528/week @ 2024-09-12 189/week @ 2024-09-19 65/week @ 2024-09-26 28/week @ 2024-10-03 91/week @ 2024-10-10 224/week @ 2024-10-17 4/week @ 2024-10-24 110/week @ 2024-10-31 23/week @ 2024-11-07 361/week @ 2024-11-14 35/week @ 2024-11-21 5/week @ 2024-11-28 118/week @ 2024-12-05

520 downloads per month

MIT license

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 and prod) with separate configurations and secrets.
  • Secret management: Manages secrets for local development and deployment. Supports 1Password and Kubeseal out of the box.

Demo

Hello World Demo


Installation

Prerequisites

Before installing rush, ensure that you have the following prerequisites installed:

  1. Rust via rustup:

    curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
    
  2. 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
      
  3. Docker and buildx: Ensure that Docker and Docker Buildx are installed for cross-compilation.

  4. 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

  1. 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
  2. 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:

  1. Initialize Secrets for Staging: Run the following command to configure secrets for the staging environment:

    rush --env staging helloworld.wonop.io secrets init
    
  2. 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]
  3. Deploying to Kubernetes: Assuming you have a Kubernetes cluster and kubectl configured, along with contexts and Docker registry configured in rushd.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:

  1. Install the necessary toolchain:

    arch -arm64 brew install SergioBenitez/osxct/x86_64-unknown-linux-gnu
    
  2. 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