5.5 KiB
☂️ Umbrel
This is the master respository of Umbrel and contains the framework for orchestration of all containerized services running on Umbrel OS.
It is platform and architecture-agnostic, thus can be used to directly spin up instances of Umbrel without installing the Umbrel OS since all orchestrated services use multi-architecture Docker images.
We run it on Raspbery Pis (ARMv7) as a part of Umbrel OS, Ubuntu (x64) for testnet.getumbrel.com and macOS (x64) for local development.
🚀 Getting started
If you're looking to run Umbrel on:
- A Raspberry Pi 3 or 4 (recommended) - Download Umbrel OS
- Anything else (experimental) - Install Umbrel
🎹 Services orchestrated
Architecture
+ -------------------- +
| umbrel-dashboard |
+ -------------------- +
|
|
+ ------------- +
| nginx |
+ ------------- +
|
|
+ - - - - - - - - - - - + - - - - - - - - - - - +
| |
| |
+ ------------------ + + --------------------- +
| umbrel-manager | < - - - jwt auth - - - | umbrel-middleware |
+ ------------------ + + --------------------- +
|
|
+ - - - - - - - - + - - - - - - - - +
| |
| |
+ ------------- + + ------------- +
| bitcoind | < - - - - - - - - | lnd |
+ ------------- + + ------------- +
🛠 Installation
Requirements
- Docker
- Python 3.0+
- Docker Compose (installed via python3 pip)
Ensure that your account is correctly permissioned to use docker.
Step 1. Run this from your home directory (if installing on dedicated hardware)
It will clone this repo while preserving home directory's existing structure.
curl -L https://github.com/getumbrel/umbrel/archive/v0.1.6-beta.3.tar.gz | tar -xz --strip-components=1
Step 2. Configure
# To configure Umbrel for mainnet, run:
./scripts/configure
# For testnet, run:
TESTNET=1 ./scripts/configure
# For regtest, run:
REGTEST=1 ./scripts/configure
Step 3. Run Umbrel
sudo ./scripts/start
⚡️ Don't be too reckless
Umbrel is still in early development and things are expected to break every now and then. We DO NOT recommend running it on the mainnet with real money just yet, unless you want to be really #reckless.
❤️ Contributing
We welcome and appreciate new contributions.
If you're a developer looking to help but not sure where to begin, check out these issues that have specifically been marked as being friendly to new contributors.
If you're looking for a bigger challenge, before opening a pull request please create an issue or join our community chat to get feedback, discuss the best way to tackle the challenge, and to ensure that there's no duplication of work.