Add nginx Docker setup for persistent serving on :43036

- Dockerfile: nginx:1.27-alpine, copies static files + nginx.conf
- nginx.conf: gzip, long cache for images, short cache for HTML/JS,
  SPA fallback to index.html (hash router handles /#/projects/<slug>)
- docker-compose.yml: restart unless-stopped, healthcheck on :43036
- README: docker compose up -d --build

Keeps port 43036 so the existing nginx-proxy-manager route for
wilddragon.net (-> :43036) keeps working without reconfig.
This commit is contained in:
Zac Gaetano 2026-05-12 11:02:55 +00:00
parent 2104388ea1
commit 6d901522d0
5 changed files with 78 additions and 5 deletions

4
.dockerignore Normal file
View file

@ -0,0 +1,4 @@
.git
.gitignore
README.md
DEPLOY.md

12
Dockerfile Normal file
View file

@ -0,0 +1,12 @@
FROM nginx:1.27-alpine
COPY nginx.conf /etc/nginx/conf.d/default.conf
WORKDIR /usr/share/nginx/html
COPY index.html standalone.html styles.css data.js projects-data.js components.jsx tweaks-panel.jsx llms.txt ./
COPY images ./images
EXPOSE 43036
HEALTHCHECK --interval=30s --timeout=5s --retries=3 \
CMD wget -q --spider http://localhost:43036/ || exit 1

View file

@ -20,15 +20,21 @@ standalone.html — fully self-contained single-file build (all images base6
## Serve
Any static file server works:
**Docker (production / persistent):**
```
python3 -m http.server 8080
# or
npx serve .
docker compose up -d --build
```
Then open <http://localhost:8080/>.
Container `wilddragon-site` exposes nginx on port `43036`. Nginx Proxy Manager fronts it for `wilddragon.net`.
**Local quick check:**
```
python3 -m http.server 8081
```
Then open <http://localhost:8081/>.
## Single-file build

13
docker-compose.yml Normal file
View file

@ -0,0 +1,13 @@
services:
wilddragon:
build: .
image: wilddragon-site:latest
container_name: wilddragon-site
restart: unless-stopped
ports:
- "43036:43036"
healthcheck:
test: ["CMD", "wget", "-q", "--spider", "http://localhost:43036/"]
interval: 30s
timeout: 5s
retries: 3

38
nginx.conf Normal file
View file

@ -0,0 +1,38 @@
server {
listen 43036 default_server;
listen [::]:43036 default_server;
server_name _;
root /usr/share/nginx/html;
index index.html;
charset utf-8;
gzip on;
gzip_types text/plain text/css text/javascript application/javascript application/json image/svg+xml;
gzip_min_length 1024;
# Long cache for static assets they're content-addressed by path,
# bust via filename when they change.
location ~* \.(png|jpg|jpeg|gif|webp|svg|ico|woff2?|ttf)$ {
expires 30d;
add_header Cache-Control "public, immutable";
}
# Short cache for the HTML/JS that drive the SPA so edits show up fast.
location ~* \.(html|css|js|jsx)$ {
expires 5m;
add_header Cache-Control "public, must-revalidate";
}
# Single-page app unknown paths fall back to index.html, which
# handles routing via location.hash (#/projects/<slug>).
location / {
try_files $uri $uri/ /index.html;
}
# llms.txt let crawlers pull it without rewrites.
location = /llms.txt {
default_type text/plain;
}
}