Update Dockerfile

This commit is contained in:
wixxidevelop 2025-07-01 11:32:56 +01:00 committed by GitHub
parent 814fd2786e
commit 19ff2be8f2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -1,57 +1,79 @@
FROM node:18-alpine AS base FROM node:18-alpine AS base
# Install dependencies only when needed
FROM base AS deps FROM base AS deps
RUN apk add --no-cache libc6-compat RUN apk add --no-cache libc6-compat
WORKDIR /app WORKDIR /app
COPY package.json yarn.lock ./ # Copy package files
COPY package.json yarn.lock* ./
RUN yarn config set registry 'https://registry.npmmirror.com/' # Configure yarn and install dependencies
RUN yarn install RUN yarn config set registry 'https://registry.npmmirror.com/' && \
yarn install --frozen-lockfile
# Rebuild the source code only when needed
FROM base AS builder FROM base AS builder
RUN apk update && apk add --no-cache git RUN apk update && apk add --no-cache git
ENV OPENAI_API_KEY=""
ENV GOOGLE_API_KEY=""
ENV CODE=""
WORKDIR /app WORKDIR /app
# Copy node_modules from deps stage
COPY --from=deps /app/node_modules ./node_modules COPY --from=deps /app/node_modules ./node_modules
COPY . . COPY . .
# Set build-time environment variables
ENV NEXT_TELEMETRY_DISABLED 1
ENV NODE_ENV production
# Build the application
RUN yarn build RUN yarn build
# Production image, copy all the files and run next
FROM base AS runner FROM base AS runner
WORKDIR /app WORKDIR /app
RUN apk add proxychains-ng # Install proxychains for proxy support
RUN apk add --no-cache proxychains-ng
# Set runtime environment
ENV NODE_ENV production
ENV NEXT_TELEMETRY_DISABLED 1
# Environment variables (will be overridden at runtime)
ENV PROXY_URL="" ENV PROXY_URL=""
ENV OPENAI_API_KEY="" ENV OPENAI_API_KEY=""
ENV GOOGLE_API_KEY="" ENV GOOGLE_API_KEY=""
ENV CODE="" ENV CODE=""
ENV ENABLE_MCP="" ENV ENABLE_MCP=""
COPY --from=builder /app/public ./public # Create a non-root user
COPY --from=builder /app/.next/standalone ./ RUN addgroup --system --gid 1001 nodejs && \
COPY --from=builder /app/.next/static ./.next/static adduser --system --uid 1001 nextjs
COPY --from=builder /app/.next/server ./.next/server
RUN mkdir -p /app/app/mcp && chmod 777 /app/app/mcp # Copy built application
COPY --from=builder /app/public ./public
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
# Create and set up MCP directory
RUN mkdir -p /app/app/mcp && \
chmod 777 /app/app/mcp
COPY --from=builder /app/app/mcp/mcp_config.default.json /app/app/mcp/mcp_config.json COPY --from=builder /app/app/mcp/mcp_config.default.json /app/app/mcp/mcp_config.json
# Switch to non-root user
USER nextjs
EXPOSE 3000 EXPOSE 3000
ENV PORT 3000
ENV HOSTNAME "0.0.0.0"
# Start the application
CMD if [ -n "$PROXY_URL" ]; then \ CMD if [ -n "$PROXY_URL" ]; then \
export HOSTNAME="0.0.0.0"; \
protocol=$(echo $PROXY_URL | cut -d: -f1); \ protocol=$(echo $PROXY_URL | cut -d: -f1); \
host=$(echo $PROXY_URL | cut -d/ -f3 | cut -d: -f1); \ host=$(echo $PROXY_URL | cut -d/ -f3 | cut -d: -f1); \
port=$(echo $PROXY_URL | cut -d: -f3); \ port=$(echo $PROXY_URL | cut -d: -f3); \
conf=/etc/proxychains.conf; \ conf=/tmp/proxychains.conf; \
echo "strict_chain" > $conf; \ echo "strict_chain" > $conf; \
echo "proxy_dns" >> $conf; \ echo "proxy_dns" >> $conf; \
echo "remote_dns_subnet 224" >> $conf; \ echo "remote_dns_subnet 224" >> $conf; \
@ -61,7 +83,6 @@ CMD if [ -n "$PROXY_URL" ]; then \
echo "localnet ::1/128" >> $conf; \ echo "localnet ::1/128" >> $conf; \
echo "[ProxyList]" >> $conf; \ echo "[ProxyList]" >> $conf; \
echo "$protocol $host $port" >> $conf; \ echo "$protocol $host $port" >> $conf; \
cat /etc/proxychains.conf; \
proxychains -f $conf node server.js; \ proxychains -f $conf node server.js; \
else \ else \
node server.js; \ node server.js; \