90 lines
3.0 KiB
Markdown
90 lines
3.0 KiB
Markdown
# Michael's Homelab
|
|
|
|
Welcome to the container farm...
|
|
|
|
## Host List
|
|
|
|
### Devices
|
|
|
|
| Host | OS | Purpose / Services |
|
|
| :--- | :--- | :----------------- |
|
|
| [Thonkpad](thonkpad/) (portable) | data:image/s3,"s3://crabby-images/d9451/d94512eb372bc00845df69facda4cf267948213a" alt="Fedora" | Misc. Projects |
|
|
| [Cuddlefish](cuddlefish/) | data:image/s3,"s3://crabby-images/87cae/87caea8df3653d2adbe36b3bf5d14f75bac5865b" alt="CentOS" | Gitea |
|
|
| [Rocktiplex](rocktiplex/) | data:image/s3,"s3://crabby-images/0ad96/0ad964a89c2b0d6b379c002465f43d2fc57955e9" alt="Rocky Linux" | Fathom, Status Proxy, [RSF Analytics](https://rsf.michaellisano.com), [ytpod](https://ytpod.michaellisano.com/) |
|
|
| Cloud8 (under repair) | data:image/s3,"s3://crabby-images/0ad96/0ad964a89c2b0d6b379c002465f43d2fc57955e9" alt="Rocky Linux" | NextCloud |
|
|
|
|
### Virtualized Hosts
|
|
|
|
| VM | Kind | Access | Machine | OS | Purpose / Services |
|
|
| :--- | :--- | :----- | :------ | :--- | :----------------- |
|
|
| [NixHost](thonkpad/nixhost/) | KVM | SSH | Thonkpad | data:image/s3,"s3://crabby-images/d6300/d63008b3bcba5389f7ab3836b737001d26e2ea7f" alt="NixOS" | NixOS Testbed |
|
|
| [WinHost](thonkpad/winhost/) | KVM | RDP | Thonkpad | data:image/s3,"s3://crabby-images/6bd23/6bd236db4877809e1f0745bd20ffdb7198539cdf" alt="Windows 10" | Altium Designer |
|
|
|
|
### Off-site
|
|
|
|
| Host | Provider | OS | Purpose / Services |
|
|
| :--- | :------- | :--- | :----------------- |
|
|
| Backup1 | [TNAHosting](https://tnahosting.net/) | data:image/s3,"s3://crabby-images/0e261/0e261103dd9728520b41aa426ac027cc18e58ba1" alt="Ubuntu" | Docker Volume Backups |
|
|
|
|
## Docker
|
|
|
|
Most services are run as Docker containers.
|
|
|
|
### Volume Permission Notes
|
|
|
|
In a standard setup, we will have a `docker` usergroup. To make a *user-created directory* usable as a volume, run the following:
|
|
|
|
```bash
|
|
sudo chown -R my-user:docker my-dir
|
|
```
|
|
|
|
### SELinux Notes
|
|
|
|
Docker volumes violate some SELinux policies. Use `setenforce 0` to disable it temporarily, or make the following permanent change to `/etc/sysconfig/selinux`:
|
|
|
|
```bash
|
|
# SELINUX=enforcing
|
|
SELINUX=permissive
|
|
```
|
|
|
|
### Dockerized Cloudflared Notes
|
|
|
|
If a docker-compose file looks like this:
|
|
|
|
```yaml
|
|
services:
|
|
gitea-server:
|
|
image: gitea/gitea:1.19.3
|
|
# ...
|
|
gitea-cloudflared:
|
|
image: cloudflare/cloudflared
|
|
# ...
|
|
```
|
|
|
|
Then in this case the name of the target service is `gitea-server`, and (per Docker's networking shenanigans), should be specified **directly by service name,** e.g.
|
|
|
|
```
|
|
https://git.michaellisano.com -> http://gitea-server:3000
|
|
```
|
|
|
|
## Backups
|
|
|
|
Everything is encrypted with [age](https://github.com/FiloSottile/age).
|
|
|
|
All keys are generated using age-keygen and stored in a text file, e.g.
|
|
|
|
**backup-key.txt**
|
|
|
|
```
|
|
# created: 2023-06-24T18:01:36-07:00
|
|
# public key: age12345...
|
|
AGE-SECRET-KEY-xyz123...
|
|
```
|
|
|
|
Decrypting a file:
|
|
|
|
```
|
|
age -d -i backup-key.txt -o NAME.tar.gz NAME.tar.gz.enc
|
|
```
|
|
|