Add Docker setup with maintenance page and health check endpoint

This commit is contained in:
greg 2025-04-27 22:08:07 +02:00
parent 57aaab43f1
commit 801e16c9af
2 changed files with 32 additions and 98 deletions

View File

@ -1,33 +1,6 @@
# Versioning and metadata
.git
.gitignore
.dockerignore
# Ignore everything
*
**/*
# Build dependencies
node_modules
npm-debug.log
# Environment (contains sensitive data)
.env
.env.*
!.env.example
# Files not required for production
README.md
Dockerfile
docker-compose.yml
*.log
.next
.vscode
.idea
*.md
*.log
*.lock
# Testing
coverage
.nyc_output
test
# Misc
.DS_Store
# Except the Dockerfile itself
!Dockerfile

View File

@ -1,69 +1,48 @@
# Self-contained Dockerfile that creates all necessary files
# Minimal self-contained Dockerfile - no external files needed
FROM node:16-alpine
# Create app directory
WORKDIR /app
# Create server.js file directly in the Dockerfile
RUN echo 'const http = require("http");\n\
# Create a simple server.js file directly in the container
RUN echo '// Simple HTTP server\n\
const http = require("http");\n\
const fs = require("fs");\n\
const path = require("path");\n\
\n\
// Create the src/app directory if it doesn\'t exist\n\
fs.mkdirSync(path.join(__dirname, "src", "app"), { recursive: true });\n\
// Create directory for HTML file\n\
fs.mkdirSync(path.join(__dirname, "public"), { recursive: true });\n\
\n\
// Create a simple HTML file\n\
const htmlContent = `<!DOCTYPE html>\n\
<html lang="en">\n\
// Create HTML content\n\
const html = `<!DOCTYPE html>\n\
<html>\n\
<head>\n\
<title>My Favorites - Maintenance</title>\n\
<meta charset="UTF-8">\n\
<meta name="viewport" content="width=device-width, initial-scale=1.0">\n\
<title>My Favorites - Maintenance</title>\n\
<style>\n\
body {\n\
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;\n\
background-color: #f5f5f0;\n\
color: #333;\n\
display: flex;\n\
flex-direction: column;\n\
align-items: center;\n\
justify-content: center;\n\
height: 100vh;\n\
margin: 0;\n\
padding: 20px;\n\
text-align: center;\n\
}\n\
.container {\n\
max-width: 600px;\n\
padding: 40px;\n\
background-color: white;\n\
border-radius: 8px;\n\
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);\n\
}\n\
h1 {\n\
color: #3b82f6;\n\
margin-bottom: 16px;\n\
}\n\
p {\n\
line-height: 1.6;\n\
margin-bottom: 24px;\n\
}\n\
body { font-family: sans-serif; background: #f5f5f0; display: flex; justify-content: center; align-items: center; height: 100vh; margin: 0; }\n\
.container { max-width: 600px; padding: 40px; background: white; border-radius: 8px; box-shadow: 0 2px 10px rgba(0,0,0,0.1); text-align: center; }\n\
h1 { color: #3b82f6; }\n\
</style>\n\
</head>\n\
<body>\n\
<div class="container">\n\
<h1>My Favorites</h1>\n\
<p>Our application is currently undergoing maintenance. We\'ll be back shortly with a collection of books, movies, series, and more that have made an impression.</p>\n\
<p>Our application is currently undergoing maintenance.</p>\n\
<p>We will be back shortly with a collection of books, movies, series, and more that have made an impression.</p>\n\
<p>Thank you for your patience!</p>\n\
</div>\n\
</body>\n\
</html>`;\n\
\n\
fs.writeFileSync(path.join(__dirname, "src", "app", "index.html"), htmlContent);\n\
// Write HTML to file\n\
fs.writeFileSync(path.join(__dirname, "public", "index.html"), html);\n\
\n\
// Create HTTP server\n\
// Create server\n\
const server = http.createServer((req, res) => {\n\
console.log(`Request received: ${req.method} ${req.url}`);\n\
// Log request\n\
console.log(`${new Date().toISOString()} - ${req.method} ${req.url}`);\n\
\n\
// Health check endpoint\n\
if (req.url === "/health" || req.url === "/api/health") {\n\
@ -72,13 +51,12 @@ const server = http.createServer((req, res) => {\n\
return;\n\
}\n\
\n\
// Serve static HTML for all other routes\n\
const indexPath = path.join(__dirname, "src", "app", "index.html");\n\
fs.readFile(indexPath, (err, content) => {\n\
// Serve HTML for all other routes\n\
fs.readFile(path.join(__dirname, "public", "index.html"), (err, content) => {\n\
if (err) {\n\
res.writeHead(500);\n\
res.end("Error loading index.html");\n\
console.error("Error serving index.html:", err);\n\
res.end("Error loading page");\n\
console.error("Error:", err);\n\
return;\n\
}\n\
\n\
@ -87,34 +65,17 @@ const server = http.createServer((req, res) => {\n\
});\n\
});\n\
\n\
// Start the server\n\
// Start server\n\
const PORT = process.env.PORT || 3000;\n\
server.listen(PORT, () => {\n\
server.listen(PORT, "0.0.0.0", () => {\n\
console.log(`Server running on port ${PORT}`);\n\
console.log(`Environment: ${process.env.NODE_ENV || "development"}`);\n\
});\n\
\n\
// Handle errors\n\
server.on("error", (err) => {\n\
console.error("Server error:", err);\n\
});\n\
\n\
// Handle process termination\n\
process.on("SIGTERM", () => {\n\
console.log("SIGTERM received, shutting down gracefully");\n\
server.close(() => {\n\
console.log("Server closed");\n\
process.exit(0);\n\
});\n\
});\n\
\n\
process.on("uncaughtException", (err) => {\n\
console.error("Uncaught exception:", err);\n\
});\n\
\n\
process.on("unhandledRejection", (reason) => {\n\
console.error("Unhandled rejection:", reason);\n\
});' > server.js
' > server.js
# Set environment variables
ENV NODE_ENV=production