Skip to content

Latest commit

 

History

History
58 lines (45 loc) · 1.64 KB

README.md

File metadata and controls

58 lines (45 loc) · 1.64 KB

laby

My lab in Docker with domain laby.ooo

This is to demo the a Web application interacting with a Database. All is behind a Reverse Proxy.

The application is a Grafana dashboard to visualize Prometheus metrics. HTTPS SSL traffic is offloaded by Traefik. Alt text

Local host file edit

/etc/hosts
127.0.0.1 grafana.laby.ooo
127.0.0.1 laby.ooo
127.0.0.1 www.laby.ooo

Local CA (can skip if use certs folder)

openssl genpkey -algorithm RSA -out ca.key
openssl req -new -x509 -key ca.key -out ca.crt

# Or can use the existing CA in `certs` folder

Add LocalCA to MacOS Keychain

This is to make Chrome trust the above SelfSigned custom generated CA

  1. Double click on ca.crt to add it to MacOS Keychain
  2. Open Keychain -> Highlight the ca.crt -> Right click -> Get info
  3. Change to Trust

Alt text

Private Key and CSR generating (can skip if use certs folder)

cd certs
openssl req -new -key laby.ooo.key -out laby.ooo.csr -subj "/CN=laby.ooo"

Sign CSR with Local CA (can skip if use certs folder)

cd certs
openssl x509 -req -in laby.ooo.csr -CA ./ca/ca.crt -CAkey ./ca/ca.key -CAcreateserial -extfile ./ca/openssl.ss.cnf -out laby.ooo.crt -days 730 -sha256

Run it !

# Stand at root of this repo folder
docker-compose up

Access the App

  1. Open Chrome or whatever browser
  2. Type https://grafana.laby.ooo
  3. Default username and password are 'admin'
  4. Add whatever Prometheus dashboard available on Grafana dashboards page

Alt text