fix: Complete static server (bypass Astro preview entirely)

- Use 'serve' static file server instead of 'astro preview'
- Static server has NO host restrictions (pure HTTP)
- Bypass Astro preview host validation entirely
- Astro built to static files in build stage
- Serve static HTML/CSS/JS in production stage
- Fixes ALL host restriction issues (403 + blocked request)
This commit is contained in:
Kunthawat
2026-03-12 13:27:23 +07:00
parent 18fc8171ae
commit 12040dec5b

View File

@@ -9,33 +9,33 @@ RUN npm install
COPY . .
RUN mkdir -p data
# Build project
# Build Astro to static files
RUN npm run build
# Production Stage
# Production Stage - Static Server
FROM node:20-alpine
WORKDIR /app
# Install SQLite runtime
RUN apk add --no-cache sqlite-libs
# Install serve and SQLite runtime
RUN apk add --no-cache sqlite-libs curl
# Copy package files with serve dependency
COPY package*.json ./
RUN npm install --production
RUN npm install serve --production
# Copy built assets
# Copy built static files and database
COPY --from=builder /app/dist ./dist
COPY --from=builder /app/data ./data
EXPOSE 80
# Health check
# Health check with curl
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD node -e "require('http').get('http://localhost:80', (r) => {process.exit(r.statusCode === 200 ? 0 : 1)})"
CMD curl -f http://localhost/ || exit 1
ENV NODE_ENV=production
ENV ASTRO_PORT=80
ENV ASTRO_HOST=0.0.0.0
ENV PORT=80
# Serve static files using serve package with all-host access
CMD ["npx", "serve", "--listen", "80", "--single", "dist"]
# Serve static files with NO restrictions (plain HTTP server)
CMD ["serve", "--no-clipboard", "--single", "--listen", "80", "dist"]