This guide provides detailed instructions for installing Joblet on various operating systems and architectures.
🚀 Docker Alternative: Joblet is a modern replacement for Docker and Docker Compose, providing superior performance, security, and resource control through Linux namespaces and cgroups v2. Install Joblet directly on Linux hosts for optimal performance - no containers required!
# Update package list
sudo apt update
# Install dependencies
sudo apt install -y curl tar make gcc
# Download and install
curl -L https://github.com/ehsaniara/joblet/releases/latest/download/joblet-linux-amd64.tar.gz | tar xz
sudo mv joblet /usr/local/bin/
sudo mv rnx /usr/local/bin/
sudo chmod +x /usr/local/bin/joblet /usr/local/bin/rnx
# Create directories
sudo mkdir -p /opt/joblet/{config,state,certs,jobs,volumes}
sudo mkdir -p /var/log/joblet
# Verify installation
joblet --version
rnx --version
# Install dependencies
sudo dnf install -y curl tar make gcc
# Download and install
curl -L https://github.com/ehsaniara/joblet/releases/latest/download/joblet-linux-amd64.tar.gz | tar xz
sudo mv joblet /usr/local/bin/
sudo mv rnx /usr/local/bin/
sudo chmod +x /usr/local/bin/joblet /usr/local/bin/rnx
# Create directories
sudo mkdir -p /opt/joblet/{config,state,certs,jobs,volumes}
sudo mkdir -p /var/log/joblet
# Enable cgroups v2 if needed
sudo grubby --update-kernel=ALL --args="systemd.unified_cgroup_hierarchy=1"
# Reboot required after this change
# Install dependencies
sudo yum install -y curl tar make gcc
# Download and install
curl -L https://github.com/ehsaniara/joblet/releases/latest/download/joblet-linux-amd64.tar.gz | tar xz
sudo mv joblet /usr/local/bin/
sudo mv rnx /usr/local/bin/
sudo chmod +x /usr/local/bin/joblet /usr/local/bin/rnx
# Create directories
sudo mkdir -p /opt/joblet/{config,state,certs,jobs,volumes}
sudo mkdir -p /var/log/joblet
# Install from AUR (if available)
yay -S joblet
# Or manual installation
sudo pacman -S curl tar make gcc
curl -L https://github.com/ehsaniara/joblet/releases/latest/download/joblet-linux-amd64.tar.gz | tar xz
sudo mv joblet /usr/local/bin/
sudo mv rnx /usr/local/bin/
# Download ARM64 version
curl -L https://github.com/ehsaniara/joblet/releases/latest/download/joblet-linux-arm64.tar.gz | tar xz
sudo mv joblet /usr/local/bin/
sudo mv rnx /usr/local/bin/
sudo chmod +x /usr/local/bin/joblet /usr/local/bin/rnx
# Add Joblet tap
brew tap ehsaniara/joblet
# Install RNX client
brew install rnx
# Intel Macs
curl -L https://github.com/ehsaniara/joblet/releases/latest/download/rnx-darwin-amd64.tar.gz | tar xz
# Apple Silicon (M1/M2)
curl -L https://github.com/ehsaniara/joblet/releases/latest/download/rnx-darwin-arm64.tar.gz | tar xz
# Install
sudo mv rnx /usr/local/bin/
sudo chmod +x /usr/local/bin/rnx
# Create config directory
mkdir -p ~/.rnx
# Add Joblet bucket
scoop bucket add joblet https://github.com/ehsaniara/scoop-joblet
# Install RNX
scoop install rnx
Extract to a directory (e.g., C:\Program Files\Joblet
)
[Environment]::SetEnvironmentVariable("Path", $env:Path + ";C:\Program Files\Joblet", "User")
mkdir $env:USERPROFILE\.rnx
# Clone repository
git clone https://github.com/ehsaniara/joblet.git
cd joblet
# Build all binaries
make build
# Or build manually
go build -o joblet ./cmd/joblet
go build -o rnx ./cmd/rnx
# Run tests
make test
# Install binaries
sudo make install
# Build for Linux AMD64
GOOS=linux GOARCH=amd64 go build -o joblet-linux-amd64 ./cmd/joblet
# Build for macOS ARM64
GOOS=darwin GOARCH=arm64 go build -o rnx-darwin-arm64 ./cmd/rnx
# Build for Windows
GOOS=windows GOARCH=amd64 go build -o rnx.exe ./cmd/rnx
# Set server address (REQUIRED)
export JOBLET_SERVER_ADDRESS='192.168.1.100' # Use your server's IP
# Generate certificates with embedded configuration
sudo /usr/local/bin/certs_gen_embedded.sh
This creates:
/opt/joblet/config/joblet-config.yml
- Server config with embedded certificates/opt/joblet/config/rnx-config.yml
- Client config with embedded certificates# Create CA
openssl genrsa -out ca-key.pem 4096
openssl req -new -x509 -key ca-key.pem -out ca-cert.pem -days 3650 \
-subj "/CN=Joblet CA"
# Create server certificate
openssl genrsa -out server-key.pem 4096
openssl req -new -key server-key.pem -out server.csr \
-subj "/CN=joblet"
openssl x509 -req -in server.csr -CA ca-cert.pem -CAkey ca-key.pem \
-out server-cert.pem -days 365 -CAcreateserial \
-extensions v3_req -extfile <(echo "[v3_req]
subjectAltName = DNS:localhost,DNS:joblet,IP:127.0.0.1,IP:${JOBLET_SERVER_ADDRESS}")
# Create client certificate
openssl genrsa -out client-key.pem 4096
openssl req -new -key client-key.pem -out client.csr \
-subj "/CN=rnx-client/OU=admin"
openssl x509 -req -in client.csr -CA ca-cert.pem -CAkey ca-key.pem \
-out client-cert.pem -days 365 -CAcreateserial
sudo tee /etc/systemd/system/joblet.service > /dev/null <<EOF
[Unit]
Description=Joblet Job Execution Service
After=network-online.target
Wants=network-online.target
[Service]
Type=simple
User=root
Group=root
ExecStart=/usr/local/bin/joblet
Restart=always
RestartSec=5
StandardOutput=journal
StandardError=journal
SyslogIdentifier=joblet
Environment="JOBLET_CONFIG_PATH=/opt/joblet/config/joblet-config.yml"
# Security settings
NoNewPrivileges=false
PrivateTmp=false
ProtectSystem=false
ProtectHome=false
[Install]
WantedBy=multi-user.target
EOF
# Reload systemd
sudo systemctl daemon-reload
# Enable service
sudo systemctl enable joblet
# Start service
sudo systemctl start joblet
# Check status
sudo systemctl status joblet
# View logs
sudo journalctl -u joblet -f
Joblet is designed as a Docker and Kubernetes alternative providing superior isolation, performance, and resource control through Linux namespaces and cgroups v2.
# Set up development environment on Linux
# Requires Linux host (VM, WSL2, or native Linux)
# Install development dependencies
sudo apt update
sudo apt install -y build-essential git protobuf-compiler
# Clone and build
git clone https://github.com/ehsaniara/joblet.git
cd joblet
make all
# Run tests
make test
# Install locally for development
sudo make install
Joblet replaces containerization technologies by providing:
Use Joblet Instead Of:
docker run
→ rnx run
docker-compose
→ rnx run --workflow=workflow.yaml
# Check if server is running
sudo systemctl is-active joblet
# Test server locally
sudo joblet --version
# Check listening port
sudo ss -tlnp | grep 50051
# Copy client config from server
scp server:/opt/joblet/config/rnx-config.yml ~/.rnx/
# Test connection
rnx list
# Run test job
rnx run echo "Installation successful!"
sudo chmod +x /usr/local/bin/joblet /usr/local/bin/rnx
# Check cgroups version
mount | grep cgroup
# Enable cgroups v2 (requires reboot)
sudo grubby --update-kernel=ALL --args="systemd.unified_cgroup_hierarchy=1"
# Find process using port
sudo lsof -i :50051
# Change port in config
# Edit /opt/joblet/config/joblet-config.yml
# Regenerate certificates
sudo rm -rf /opt/joblet/config/*.yml
sudo /usr/local/bin/certs_gen_embedded.sh