FROM python:3.12-alpine AS builder RUN pip install --no-cache-dir --no-compile \ hypercorn==0.18.0 \ "cbor2>=5.4.0" \ "defusedxml>=0.7" \ "docker>=7.0.0" \ "pyyaml>=6.0" \ "cryptography>=41.0" \ "pymysql>=1.1" \ "boto3>=1.34" \ "awscli" # Strip awscli help examples (~25 MB) and Python cache files (~15 MB). RUN rm -rf /usr/local/lib/python3.12/site-packages/awscli/examples \ && find /usr/local/lib/python3.12/site-packages -type d -name '__pycache__' -exec rm -rf {} + 2>/dev/null \ && rm -rf /usr/local/lib/python3.12/site-packages/pip*.dist-info \ && rm -rf /usr/local/lib/python3.12/site-packages/pip* FROM python:3.12-alpine LABEL maintainer="MiniStack" \ description="Local AWS Service Emulator — drop-in LocalStack replacement" # Upgrade base packages to pick up latest security patches. RUN apk upgrade --no-cache && apk add --no-cache nodejs bash && rm -f /usr/bin/wget /bin/wget \ && rm -rf /usr/local/lib/python3.12/site-packages/pip* \ /usr/local/bin/pip* WORKDIR /opt/ministack # Copy cleaned Python packages and CLI entrypoints from builder. COPY --from=builder /usr/local/lib/python3.12/site-packages /usr/local/lib/python3.12/site-packages COPY --from=builder /usr/local/bin/aws /usr/local/bin/aws COPY --from=builder /usr/local/bin/aws_completer /usr/local/bin/aws_completer COPY --from=builder /usr/local/bin/hypercorn /usr/local/bin/hypercorn COPY bin/awslocal /usr/local/bin/awslocal RUN chmod +x /usr/local/bin/awslocal COPY ministack/ ministack/ RUN addgroup -S ministack && adduser -S ministack -G ministack RUN mkdir -p /tmp/ministack-data/s3 && chown -R ministack:ministack /tmp/ministack-data RUN mkdir -p /docker-entrypoint-initaws.d/ready.d \ /etc/localstack/init/boot.d \ /etc/localstack/init/ready.d && \ chown -R ministack:ministack /docker-entrypoint-initaws.d /etc/localstack VOLUME /docker-entrypoint-initaws.d VOLUME /etc/localstack/init ENV GATEWAY_PORT=4566 \ LOG_LEVEL=INFO \ S3_PERSIST=0 \ S3_DATA_DIR=/tmp/ministack-data/s3 \ REDIS_HOST=redis \ REDIS_PORT=6379 \ RDS_BASE_PORT=15432 \ RDS_PERSIST=0 \ ELASTICACHE_BASE_PORT=16379 \ LAMBDA_EXECUTOR=local \ PYTHONUNBUFFERED=1 EXPOSE 4566 # Pure Python healthcheck — no curl dependency HEALTHCHECK --interval=10s --timeout=3s --start-period=5s --retries=3 \ CMD python -c "import urllib.request; urllib.request.urlopen('http://localhost:4566/_ministack/health')" || exit 1 ENTRYPOINT ["python", "-m", "hypercorn", "ministack.app:app", "--bind", "0.0.0.0:4566", "--keep-alive", "75"]