dockerize
This commit is contained in:
parent
51c27ac9fb
commit
4bce7ce63f
@ -35,6 +35,8 @@ dashboard {
|
|||||||
## Authentication
|
## Authentication
|
||||||
##--------------------------------------------------------------------
|
##--------------------------------------------------------------------
|
||||||
|
|
||||||
|
allow_anonymous = false
|
||||||
|
|
||||||
## Load users from file
|
## Load users from file
|
||||||
authn {
|
authn {
|
||||||
enable = true
|
enable = true
|
||||||
@ -79,3 +81,8 @@ allow_anonymous = true
|
|||||||
listeners.tcp.default {
|
listeners.tcp.default {
|
||||||
bind = "0.0.0.0:1883"
|
bind = "0.0.0.0:1883"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
listeners.ws.default {
|
||||||
|
bind = "0.0.0.0:8083" # binds to all interfaces
|
||||||
|
max_connections = 102400
|
||||||
|
}
|
||||||
|
|||||||
29
console/Dockerfile
Normal file
29
console/Dockerfile
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
# ---- Build stage ----
|
||||||
|
FROM node:20-alpine AS builder
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
# install deps first (better caching)
|
||||||
|
COPY package.json package-lock.json ./
|
||||||
|
RUN npm ci
|
||||||
|
|
||||||
|
# copy source and build
|
||||||
|
COPY . .
|
||||||
|
RUN npm run build
|
||||||
|
|
||||||
|
|
||||||
|
# ---- Production stage ----
|
||||||
|
FROM nginx:alpine
|
||||||
|
|
||||||
|
# remove default nginx static files
|
||||||
|
RUN rm -rf /usr/share/nginx/html/*
|
||||||
|
|
||||||
|
# copy built app
|
||||||
|
COPY --from=builder /app/dist /usr/share/nginx/html
|
||||||
|
|
||||||
|
# optional: custom nginx config (for SPA routing)
|
||||||
|
# COPY nginx.conf /etc/nginx/conf.d/default.conf
|
||||||
|
|
||||||
|
EXPOSE 80
|
||||||
|
|
||||||
|
CMD ["nginx", "-g", "daemon off;"]
|
||||||
9
console/nginx.conf
Normal file
9
console/nginx.conf
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
index index.html;
|
||||||
|
try_files $uri $uri/ /index.html;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
function handleLogin({ username, password }) {
|
function handleLogin({ username, password }) {
|
||||||
// Create the shared MQTT client
|
// Create the shared MQTT client
|
||||||
mqtt.value = new MQTTService('ws://127.0.0.1:8083/mqtt', username, password)
|
mqtt.value = new MQTTService('wss://dmc.jonotargett.com:443/mqtt', username, password)
|
||||||
loggedIn.value = true
|
loggedIn.value = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -28,3 +28,12 @@ services:
|
|||||||
- 8189:8189/udp
|
- 8189:8189/udp
|
||||||
- 9998:9998
|
- 9998:9998
|
||||||
|
|
||||||
|
console:
|
||||||
|
build:
|
||||||
|
context: ./console
|
||||||
|
dockerfile: Dockerfile
|
||||||
|
container_name: console
|
||||||
|
ports:
|
||||||
|
- "8080:80"
|
||||||
|
depends_on:
|
||||||
|
- emqx
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user