This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
personal_infrastructure [2023/09/08 23:12] – [OS] qlyoung | personal_infrastructure [2024/06/16 01:02] (current) – [Cost] qlyoung | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | ====== personal infrastructure ====== | ||
+ | |||
+ | |||
//tldr - docker compose, isolated servers// | //tldr - docker compose, isolated servers// | ||
Line 29: | Line 32: | ||
pub((public)) | pub((public)) | ||
priv((private)) | priv((private)) | ||
- | | + | |
- | data(stores sensitive data) --> | + | onlyme{used only by me?} |
- | onlyme(used only by me) --> priv | + | data --> |
+ | data --> | ||
+ | onlyme --> | ||
+ | onlyme --> |no| pub | ||
</ | </ | ||
Line 40: | Line 46: | ||
===== Public ===== | ===== Public ===== | ||
- | For the public sphere, I use cloud-based Linux VMs from one of the affordable providers. I run most of my stuff on a single shared CPU VM with 4 CPU cores, | + | For the public sphere, I use cloud-based Linux VMs from one of the affordable providers. I run most of my stuff on a single shared CPU VM with 4 CPU cores, |
For things that need to be exposed in the internet I think cloud is the best choice. From a network isolation perspective serving things from your home means untrusted traffic will be flowing within your home network. Apart from security concerns there are other problems: | For things that need to be exposed in the internet I think cloud is the best choice. From a network isolation perspective serving things from your home means untrusted traffic will be flowing within your home network. Apart from security concerns there are other problems: | ||
Line 49: | Line 55: | ||
* Dynamic IP addresses makes access annoying | * Dynamic IP addresses makes access annoying | ||
* Advertising your home IP address is a mild security concern | * Advertising your home IP address is a mild security concern | ||
+ | * can be mitigated if you rent an ultra cheap VPS and use it as a gateway; I did this initially but realized I can run everything on a cheap vps to begin with | ||
* Weather / residential power outages impact uptime | * Weather / residential power outages impact uptime | ||
Line 241: | Line 248: | ||
</ | </ | ||
- | If possible, I also configure applications so that users are served files directly from B2 rather than having them proxied through my VM, which improves performance both in terms of load time and bandwidth usage. When you watch a video on my Peertube server, your browser is downloading the video directly from B2, instead of `B2 → VM → You`. | + | If possible, I also configure applications so that users are served files directly from B2 rather than having them proxied through my VM, which improves performance both in terms of load time and bandwidth usage. When you watch a video on my Peertube server, your browser is downloading the video directly from B2, instead of '' |
====== DNS & HTTP & TLS ====== | ====== DNS & HTTP & TLS ====== | ||
Line 268: | Line 275: | ||
===== DNS ===== | ===== DNS ===== | ||
- | Each service is on its own subdomain. All subdomains | + | Each service is on its own subdomain. All subdomains |
===== HTTP ===== | ===== HTTP ===== | ||
- | nginx runs on the host and binds host ports 80 and 443. All docker containers bind to `(127.0.0.1, P)` where `P` is a host port number of my choosing. Each service has its own subdomain and a corresponding nginx configuration: | + | nginx runs on the host and binds host ports 80 and 443. All docker containers bind to '' |
< | < | ||
Line 383: | Line 390: | ||
</ | </ | ||
- | 4. Set up new `CNAME` record; | + | 4. Set up new '' |
5. Configure nginx, request and install TLS certificate | 5. Configure nginx, request and install TLS certificate | ||
<code bash> | <code bash> | ||
Line 394: | Line 401: | ||
$ certbot --nginx -d recipes.qlyoung.net | $ certbot --nginx -d recipes.qlyoung.net | ||
</ | </ | ||
+ | |||
6. ??? | 6. ??? | ||
7. Profit | 7. Profit | ||
Line 399: | Line 407: | ||
The deployment process is identical for both internal and external services. | The deployment process is identical for both internal and external services. | ||
- | ===== Backups ===== | + | ====== Backups |
Everything, private and public, is backed up with [[https:// | Everything, private and public, is backed up with [[https:// | ||
- | ===== Cost ===== | + | ====== Cost ====== |
Line 410: | Line 418: | ||
Public bill: | Public bill: | ||
- | * Compute: $40/mo | + | * Compute: $24/mo |
* B2 Storage (~200gb): ~$2/mo | * B2 Storage (~200gb): ~$2/mo | ||
- | * Total: ~$45/mo | + | |
+ | |||
+ | {{tag> |