Files
git.stella-ops.org/docs/03_QUICKSTART.md
2025-08-30 21:05:34 +00:00

5.1 KiB
Executable File
Raw Permalink Blame History

FiveMinute QuickStart 

Run your first container scan locally

Headsup the public αv0.1.0 image drops late2025.
Once it is published as
registry.stella-ops.org/stella-ops/stella-ops:0.1.0alpha
every command on this page works without changes.


0·What you need 🔧

Requirement Minimum Notes
OS Ubuntu22.04 • Alma 9 x8664 or arm64
Docker Engine 25 • Compose v2 docker -v
CPU / RAM 2vCPU /2GiB Devlaptop baseline
Disk 10GiB SSD SBOM cache

Tip If you already have Redis & MongoDB, skip the infra compose file and point StellaOps at those hosts via .env.


1·Fetch the signed Compose bundles 📦

# Infrastructure (Redis + MongoDB)
curl -LO https://get.stella-ops.org/docker-compose.infrastructure.yml
curl -LO https://get.stella-ops.org/docker-compose.infrastructure.yml.sig

# Core scanner stack
curl -LO https://get.stella-ops.org/docker-compose.stella-ops.yml
curl -LO https://get.stella-ops.org/docker-compose.stella-ops.yml.sig

# Verify signatures (supplychain 101)
cosign verify-blob --key https://stella-ops.org/keys/cosign.pub \
  --signature docker-compose.infrastructure.yml.sig  docker-compose.infrastructure.yml
cosign verify-blob --key https://stella-ops.org/keys/cosign.pub \
  --signature docker-compose.stella-ops.yml.sig docker-compose.stella-ops.yml

2·Create .env 🗝️


# ─── Identity (shows in reports) ───────────────────────────
STELLA_OPS_COMPANY_NAME="Acme Corp"
STELLA_OPS_ISSUER_EMAIL="ops@acme.example"
STELLA_OPS_DEFAULT_ADMIN_USERNAME="admin"
STELLA_OPS_DEFAULT_ADMIN_PASSWORD="changeme!"
STELLA_OPS_DEFAULT_JWT=""  # or load it later with
# docker --env-file .env compose -f docker-compose.stella-ops.yml exec stella set-jwt <JWT_FROM_EMAIL>


# ─── Database secrets ──────────────────────────────────────
MONGO_INITDB_ROOT_USERNAME=stella_admin
MONGO_INITDB_ROOT_PASSWORD=$(openssl rand -base64 18)
MONGO_URL=mongodb

REDIS_PASSWORD=$(openssl rand -base64 18)
REDIS_URL=redis


    

3·Start the supporting services 🗄️

docker compose --env-file .env -f docker-compose.infrastructure.yml  pull
docker compose --env-file .env -f docker-compose.infrastructure.yml  up -d

4·Launch StellaOps 🚀

docker compose --env-file .env -f docker-compose.stella-ops.yml pull
docker compose --env-file .env -f docker-compose.stella-ops.yml up -d

Point your browser at https://<host>:8443 the certificate is selfsigned in the alpha. Default credentials: admin / changeme (rotate immediately!).


5·Run a scan 🔍

docker compose --env-file .env -f docker-compose.stella-ops.yml \
  exec stella-ops stella scan alpine:3.20
  • First scan downloads CVE feeds (~50MB).
  • Warm scans finish in 5s on a 4vCPU host thanks to the ΔSBOM engine.

6·Reload or add a token later 🔄

# After adding STELLA_JWT to .env …
docker compose --env-file .env -f docker-compose.stella-ops.yml \
  exec stella-ops stella jwt <JWT_FROM_EMAIL>

Anonymous mode{{ quota_anon }} scans/day
Token mode{{ quota_token }} scans/day
At 10% of the daily max a polite reminder appears; after {{ quota_token }} the server applies a soft 5s backoff and may return 429 + RetryAfter until the daily reset.


7·Typical next steps ➡️

Task Where to look
CI pipelines (GitHub / GitLab / Jenkins) docs/ci/
Airgapped install Offline Update Kit
Feature overview 20_FEATURES.md
Governance & licence LICENSE.md11_GOVERNANCE.md

8·Uninstall / cleanup 🧹

docker compose --env-file .env -f docker-compose.stella-ops.yml down -v
docker compose --env-file .env -f docker-compose.infrastructure.yml  down -v
rm compose-*.yml compose-*.yml.sig .env

Licence & provenance 📜

StellaOps is AGPL3.0orlater. Every release ships:

  • Cosignsigned container images
  • A full SPDX2.3 SBOM
cosign verify \
  --key https://stella-ops.org/keys/cosign.pub \
  registry.stella-ops.org/stella-ops/stella-ops:<VERSION>

©20252026StellaOps free / libre / opensource.