fix: simplify Docker build to resolve multi-platform failures
## Root cause - Docker buildx memory options were incorrectly formatted - Database build during Docker image creation was failing on multi-platform builds - n8n native dependencies caused issues across different architectures ## Solution - Removed invalid buildx driver-opts configuration - Eliminated database build stage from Dockerfile - Now using pre-built nodes.db file (11MB) from repository - Fixed .dockerignore to include nodes.db in build context - Added .dockerignore to version control (was incorrectly gitignored) ## Benefits - Faster builds (no n8n package installation during build) - More reliable multi-platform builds (amd64 + arm64) - Simpler Dockerfile (3 stages instead of 4) Database can still be rebuilt locally using 'npm run rebuild' when needed. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
52
.dockerignore
Normal file
52
.dockerignore
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
# .dockerignore
|
||||||
|
node_modules
|
||||||
|
npm-debug.log
|
||||||
|
.git
|
||||||
|
.gitignore
|
||||||
|
.env
|
||||||
|
.env.local
|
||||||
|
# Keep nodes.db but exclude other database files
|
||||||
|
data/*.db
|
||||||
|
!data/nodes.db
|
||||||
|
dist
|
||||||
|
.DS_Store
|
||||||
|
*.log
|
||||||
|
coverage
|
||||||
|
.nyc_output
|
||||||
|
.vscode
|
||||||
|
.idea
|
||||||
|
*.swp
|
||||||
|
*.swo
|
||||||
|
*~
|
||||||
|
docker-compose.override.yml
|
||||||
|
.github
|
||||||
|
docs
|
||||||
|
tests
|
||||||
|
jest.config.js
|
||||||
|
.eslintrc.js
|
||||||
|
*.md
|
||||||
|
!README.md
|
||||||
|
!LICENSE
|
||||||
|
# Exclude n8n-docs if present
|
||||||
|
../n8n-docs
|
||||||
|
n8n-docs
|
||||||
|
# Exclude extracted nodes
|
||||||
|
extracted-nodes/
|
||||||
|
# Exclude temp directory
|
||||||
|
temp/
|
||||||
|
# Exclude any backup or temporary files
|
||||||
|
*.bak
|
||||||
|
*.tmp
|
||||||
|
*.temp
|
||||||
|
# Exclude build artifacts
|
||||||
|
build/
|
||||||
|
out/
|
||||||
|
# Exclude local development files
|
||||||
|
.eslintcache
|
||||||
|
.stylelintcache
|
||||||
|
# Exclude any large test data
|
||||||
|
test-data/
|
||||||
|
# Exclude Docker files during build
|
||||||
|
Dockerfile*
|
||||||
|
docker-compose*.yml
|
||||||
|
.dockerignore
|
||||||
7
.github/workflows/docker-build.yml
vendored
7
.github/workflows/docker-build.yml
vendored
@@ -34,10 +34,6 @@ jobs:
|
|||||||
- name: Set up Docker Buildx
|
- name: Set up Docker Buildx
|
||||||
id: buildx
|
id: buildx
|
||||||
uses: docker/setup-buildx-action@v3
|
uses: docker/setup-buildx-action@v3
|
||||||
with:
|
|
||||||
driver-opts: |
|
|
||||||
memory=8g
|
|
||||||
memory-swap=16g
|
|
||||||
|
|
||||||
- name: Log in to GitHub Container Registry
|
- name: Log in to GitHub Container Registry
|
||||||
if: github.event_name != 'pull_request'
|
if: github.event_name != 'pull_request'
|
||||||
@@ -74,9 +70,6 @@ jobs:
|
|||||||
build-args: |
|
build-args: |
|
||||||
BUILDKIT_INLINE_CACHE=1
|
BUILDKIT_INLINE_CACHE=1
|
||||||
provenance: false
|
provenance: false
|
||||||
# Add build constraints to prevent OOM
|
|
||||||
builder: ${{ steps.buildx.outputs.name }}
|
|
||||||
no-cache-filters: db-builder
|
|
||||||
|
|
||||||
# Nginx build commented out until Phase 2
|
# Nginx build commented out until Phase 2
|
||||||
# build-nginx:
|
# build-nginx:
|
||||||
|
|||||||
1
.gitignore
vendored
1
.gitignore
vendored
@@ -51,7 +51,6 @@ coverage/
|
|||||||
.yarn-integrity
|
.yarn-integrity
|
||||||
|
|
||||||
# Docker
|
# Docker
|
||||||
.dockerignore
|
|
||||||
docker-compose.override.yml
|
docker-compose.override.yml
|
||||||
|
|
||||||
# Miscellaneous
|
# Miscellaneous
|
||||||
|
|||||||
26
Dockerfile
26
Dockerfile
@@ -1,4 +1,4 @@
|
|||||||
# Optimized Dockerfile - builds database at build time, minimal runtime image
|
# Optimized Dockerfile - uses pre-built database for faster, more reliable builds
|
||||||
|
|
||||||
# Stage 1: Dependencies (includes n8n for building)
|
# Stage 1: Dependencies (includes n8n for building)
|
||||||
FROM node:20-alpine AS deps
|
FROM node:20-alpine AS deps
|
||||||
@@ -21,25 +21,7 @@ COPY . .
|
|||||||
# Build TypeScript
|
# Build TypeScript
|
||||||
RUN npm run build
|
RUN npm run build
|
||||||
|
|
||||||
# Stage 3: Database Builder (extracts all node info and builds database)
|
# Stage 3: Minimal Runtime (no n8n packages)
|
||||||
FROM builder AS db-builder
|
|
||||||
WORKDIR /app
|
|
||||||
# Clone n8n-docs for documentation (if available)
|
|
||||||
# Fix git SSL issues in Alpine and configure git properly
|
|
||||||
RUN apk add --no-cache git ca-certificates && \
|
|
||||||
git config --global http.sslVerify false && \
|
|
||||||
git config --global init.defaultBranch main && \
|
|
||||||
git clone --depth 1 https://github.com/n8n-io/n8n-docs.git /tmp/n8n-docs 2>/dev/null || \
|
|
||||||
echo "Warning: Could not clone n8n-docs, continuing without documentation"
|
|
||||||
ENV N8N_DOCS_PATH=/tmp/n8n-docs
|
|
||||||
# Build the complete database with source code
|
|
||||||
RUN mkdir -p data && \
|
|
||||||
npm run rebuild:optimized || \
|
|
||||||
(echo "Warning: Optimized rebuild failed, trying regular rebuild" && \
|
|
||||||
npm run rebuild) || \
|
|
||||||
(echo "Error: Database build failed" && exit 1)
|
|
||||||
|
|
||||||
# Stage 4: Minimal Runtime (no n8n packages)
|
|
||||||
FROM node:20-alpine AS runtime
|
FROM node:20-alpine AS runtime
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
@@ -69,8 +51,8 @@ RUN npm config set fetch-retries 5 && \
|
|||||||
# Copy built application
|
# Copy built application
|
||||||
COPY --from=builder /app/dist ./dist
|
COPY --from=builder /app/dist ./dist
|
||||||
|
|
||||||
# Copy pre-built database with all source code
|
# Copy pre-built database from source
|
||||||
COPY --from=db-builder /app/data/nodes.db ./data/
|
COPY data/nodes.db ./data/
|
||||||
|
|
||||||
# Copy minimal required files
|
# Copy minimal required files
|
||||||
COPY src/database/schema-optimized.sql ./src/database/
|
COPY src/database/schema-optimized.sql ./src/database/
|
||||||
|
|||||||
Reference in New Issue
Block a user