mirror of
				https://github.com/zadam/trilium.git
				synced 2025-11-04 05:28:59 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
FROM node:22.15.0-alpine AS builder
 | 
						|
RUN corepack enable
 | 
						|
 | 
						|
# Install native dependencies since we might be building cross-platform.
 | 
						|
WORKDIR /usr/src/app
 | 
						|
COPY ./dist/package.json ./dist/pnpm-lock.yaml ./docker/pnpm-workspace.yaml /usr/src/app/
 | 
						|
# We have to use --no-frozen-lockfile due to CKEditor patches
 | 
						|
RUN pnpm install --no-frozen-lockfile --prod && pnpm rebuild
 | 
						|
 | 
						|
FROM node:22.15.0-alpine
 | 
						|
# Create a non-root user with configurable UID/GID
 | 
						|
ARG USER=trilium
 | 
						|
ARG UID=1001
 | 
						|
ARG GID=1001
 | 
						|
ENV USER=${USER}
 | 
						|
ENV UID=${UID}
 | 
						|
ENV GID=${GID}
 | 
						|
 | 
						|
# Install runtime dependencies and create user with specific UID/GID
 | 
						|
RUN apk add --no-cache dumb-init && \
 | 
						|
    # Alpine uses addgroup/adduser (from busybox) instead of groupadd/useradd
 | 
						|
    addgroup -g ${GID} ${USER} && \
 | 
						|
    adduser -u ${UID} -G ${USER} -s /bin/sh -D -h /home/${USER} ${USER}
 | 
						|
 | 
						|
WORKDIR /home/${USER}/app
 | 
						|
COPY ./dist /home/${USER}/app
 | 
						|
RUN rm -rf /home/${USER}/app/node_modules/better-sqlite3
 | 
						|
COPY --from=builder /usr/src/app/node_modules/better-sqlite3 /home/${USER}/app/node_modules/better-sqlite3
 | 
						|
RUN chown -R ${USER}:${USER} /home/${USER}
 | 
						|
 | 
						|
# Configure container
 | 
						|
USER ${USER}
 | 
						|
EXPOSE 8080
 | 
						|
 | 
						|
# By default, use UID/GID that was set during build
 | 
						|
# These can be overridden at runtime
 | 
						|
ENV TRILIUM_UID=${UID}
 | 
						|
ENV TRILIUM_GID=${GID}
 | 
						|
ENV TRILIUM_DATA_DIR=/home/${USER}/trilium-data
 | 
						|
 | 
						|
# Use dumb-init as entrypoint to handle signals properly
 | 
						|
ENTRYPOINT ["/usr/bin/dumb-init", "--"]
 | 
						|
 | 
						|
# This script will handle UID/GID checks and start the app
 | 
						|
CMD [ "sh", "-c", "\
 | 
						|
if [ \"${TRILIUM_UID}\" != \"$(id -u)\" ] || [ \"${TRILIUM_GID}\" != \"$(id -g)\" ]; then \
 | 
						|
  echo \"Detected UID:GID mismatch\"; \
 | 
						|
  if [ \"${TRILIUM_GID}\" != \"$(id -g)\" ]; then \
 | 
						|
    echo \"ERROR: Cannot change GID at runtime in rootless mode.\"; \
 | 
						|
    echo \"       Please use docker run with --user ${TRILIUM_UID}:${TRILIUM_GID} instead.\"; \
 | 
						|
    exit 1; \
 | 
						|
  fi; \
 | 
						|
  if [ \"${TRILIUM_UID}\" != \"$(id -u)\" ]; then \
 | 
						|
    echo \"ERROR: Cannot change UID at runtime in rootless mode.\"; \
 | 
						|
    echo \"       Please use docker run with --user ${TRILIUM_UID}:${TRILIUM_GID} instead.\"; \
 | 
						|
    exit 1; \
 | 
						|
  fi; \
 | 
						|
fi; \
 | 
						|
# Make sure data directory has correct permissions \
 | 
						|
mkdir -p \"${TRILIUM_DATA_DIR}\"; \
 | 
						|
# Start the app \
 | 
						|
exec node ./main \
 | 
						|
" ]
 | 
						|
 | 
						|
HEALTHCHECK --start-period=10s CMD node /home/${USER}/app/docker_healthcheck.js
 |