1
0
forked from noxious/server

Updated Dockerfile

This commit is contained in:
Dennis Postma 2025-02-08 02:36:25 +01:00
parent b46989d3af
commit 1ed9c2a61f
5 changed files with 97 additions and 121 deletions

17
.dockerignore Normal file
View File

@ -0,0 +1,17 @@
node_modules
npm-debug.log
Dockerfile
.dockerignore
.git
.gitignore
README.md
.env
.env.*
docker-compose*
*.md
coverage
.vscode
.idea
dist
build
temp

View File

@ -1,44 +1,13 @@
FROM node:23.7.0-alpine FROM node:23.7.0-alpine
# Install dependencies and setup environment in a single layer
RUN npm install -g npm@11.1.0 && \
apk add --no-cache \
redis \
mariadb \
mariadb-client \
tmux \
mariadb-server-utils \
mariadb-connector-c && \
# Create non-root user and groups
addgroup -S appgroup && \
adduser -S appuser -G appgroup && \
adduser appuser mysql && \
# Setup MariaDB directories and permissions
mkdir -p /run/mysqld /var/lib/mysql /var/log/mysql && \
chown -R mysql:mysql /run/mysqld /var/lib/mysql /var/log/mysql && \
chmod 755 /run/mysqld /var/lib/mysql /var/log/mysql && \
mysql_install_db --user=mysql --datadir=/var/lib/mysql && \
touch /var/log/mysql/error.log && \
chown mysql:mysql /var/log/mysql/error.log && \
chmod 644 /var/log/mysql/error.log
WORKDIR /usr/src/app WORKDIR /usr/src/app
# Copy application files
COPY package*.json ./ COPY package*.json ./
COPY start.sh ./start.sh
RUN npm ci
COPY . . COPY . .
# Setup application permissions EXPOSE 4000
RUN npm ci --only=production && \
chmod +x ./start.sh && \
chown -R appuser:appgroup .
USER appuser CMD ["node", "run", "start"]
EXPOSE 80 6379 3306
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
CMD mariadb-admin ping -h localhost || exit 1
CMD ["./start.sh"]

View File

@ -1,4 +0,0 @@
{
"schemaVersion": 2,
"dockerfilePath" :"./Dockerfile"
}

75
docker-compose.yml Normal file
View File

@ -0,0 +1,75 @@
version: '3.8'
services:
app:
build:
context: .
dockerfile: Dockerfile
ports:
- "${PORT}:${PORT}"
environment:
- ENV=${ENV}
- HOST=${HOST}
- PORT=${PORT}
- JWT_SECRET=${JWT_SECRET}
- CLIENT_URL=${CLIENT_URL}
- REDIS_URL=${REDIS_URL}
- DB_HOST=mariadb
- DB_USER=${DB_USER}
- DB_PASS=${DB_PASS}
- DB_PORT=${DB_PORT}
- DB_NAME=${DB_NAME}
- ALLOW_DIAGONAL_MOVEMENT=${ALLOW_DIAGONAL_MOVEMENT}
- DEFAULT_CHARACTER_ZONE=${DEFAULT_CHARACTER_ZONE}
- DEFAULT_CHARACTER_POS_X=${DEFAULT_CHARACTER_POS_X}
- DEFAULT_CHARACTER_POS_Y=${DEFAULT_CHARACTER_POS_Y}
- SMTP_HOST=${SMTP_HOST}
- SMTP_PORT=${SMTP_PORT}
- SMTP_USER=${SMTP_USER}
- SMTP_PASSWORD=${SMTP_PASSWORD}
volumes:
- app-public:/user/src/app/public
- app-logs:/user/src/app/logs
depends_on:
- mariadb
- redis
restart: unless-stopped
networks:
- app-network
mariadb:
image: mariadb:10.6
environment:
- MYSQL_ROOT_PASSWORD=${DB_PASS}
- MYSQL_DATABASE=${DB_NAME}
- MYSQL_USER=${DB_USER}
- MYSQL_PASSWORD=${DB_PASS}
volumes:
- mariadb-data:/var/lib/mysql
ports:
- "${DB_PORT}:3306"
restart: unless-stopped
networks:
- app-network
command: ['mysqld', '--character-set-server=utf8mb4', '--collation-server=utf8mb4_unicode_ci']
redis:
image: redis:7-alpine
command: redis-server --appendonly yes
volumes:
- redis-data:/data
ports:
- "6379:6379"
restart: unless-stopped
networks:
- app-network
networks:
app-network:
driver: bridge
volumes:
app-public:
app-logs:
mariadb-data:
redis-data:

View File

@ -1,81 +0,0 @@
#!/bin/sh
set -eo pipefail
# Configuration
MAX_MYSQL_WAIT=60
APP_NAME="nodeapp"
MYSQL_SOCKET="/run/mysqld/mysqld.sock"
MYSQL_PID="/run/mysqld/mysqld.pid"
MYSQL_ERROR_LOG="/var/log/mysql/error.log"
# Cleanup function
cleanup() {
echo "Shutting down services..."
tmux kill-session -t $APP_NAME 2>/dev/null || true
redis-cli shutdown 2>/dev/null || true
if [ -f "$MYSQL_PID" ]; then
mysqladmin -u root shutdown 2>/dev/null || true
fi
exit 0
}
# Error handler
error_handler() {
echo "Error occurred in script at line: $1"
cleanup
exit 1
}
trap cleanup SIGTERM SIGINT
trap 'error_handler ${LINENO}' ERR
# Start Redis
echo "Starting Redis..."
redis-server --daemonize yes
until redis-cli ping > /dev/null 2>&1; do
sleep 1
done
echo "Redis started successfully"
# Start MySQL
echo "Starting MySQL..."
mariadbd \
--datadir=/var/lib/mysql \
--pid-file=$MYSQL_PID \
--socket=$MYSQL_SOCKET \
--log-error=$MYSQL_ERROR_LOG \
--bind-address=0.0.0.0 &
# Wait for MySQL
echo "Waiting for MySQL to be ready..."
COUNTER=0
until mysqladmin ping -h localhost --silent 2>/dev/null || [ $COUNTER -gt $MAX_MYSQL_WAIT ]; do
echo "Still waiting... (${COUNTER}s)"
sleep 2
COUNTER=$((COUNTER+2))
done
if [ $COUNTER -gt $MAX_MYSQL_WAIT ]; then
echo "MySQL failed to start within $MAX_MYSQL_WAIT seconds"
echo "Last few lines of MySQL error log:"
tail -n 20 $MYSQL_ERROR_LOG
exit 1
fi
echo "MySQL is ready!"
# Run migrations
echo "Running database migrations..."
npx mikro-orm-esm migration:up
# Start application
echo "Starting application..."
tmux new-session -d -s $APP_NAME "npm run start"
echo "App is running in tmux session. Attach with: tmux attach-session -t $APP_NAME"
# Monitor processes
while true; do
sleep 30
redis-cli ping > /dev/null 2>&1 || { echo "Redis died"; exit 1; }
mysqladmin ping -h localhost --silent || { echo "MySQL died"; exit 1; }
tmux has-session -t $APP_NAME 2>/dev/null || { echo "Application died"; exit 1; }
done