#### # Dockerfile de production pour Lions User Manager Server (Backend) # Multi-stage build optimisé avec sécurité renforcée # Basé sur la structure de btpxpress-server #### ## Stage 1 : Build avec Maven FROM maven:3.9.6-eclipse-temurin-17 AS builder WORKDIR /app # Copier pom.xml et télécharger les dépendances (cache Docker) COPY pom.xml . RUN mvn dependency:go-offline -B # Copier le code source COPY src ./src # Construire l'application avec profil production RUN mvn clean package -DskipTests -B -Dquarkus.profile=prod ## Stage 2 : Image de production optimisée FROM registry.access.redhat.com/ubi8/openjdk-17:1.18 ENV LANGUAGE='en_US:en' # Configuration des variables d'environnement pour production ENV QUARKUS_PROFILE=prod ENV DB_URL=jdbc:postgresql://postgresql:5432/lions_audit ENV DB_USERNAME=lions_audit_user ENV DB_PASSWORD=changeme ENV SERVER_PORT=8080 # Configuration Keycloak/OIDC (production) ENV QUARKUS_OIDC_AUTH_SERVER_URL=https://security.lions.dev/realms/master ENV QUARKUS_OIDC_CLIENT_ID=lions-user-manager ENV KEYCLOAK_CLIENT_SECRET=changeme ENV QUARKUS_OIDC_TLS_VERIFICATION=required # Configuration Keycloak Admin Client ENV LIONS_KEYCLOAK_SERVER_URL=https://security.lions.dev ENV LIONS_KEYCLOAK_ADMIN_REALM=master ENV LIONS_KEYCLOAK_ADMIN_CLIENT_ID=admin-cli ENV LIONS_KEYCLOAK_ADMIN_USERNAME=admin ENV LIONS_KEYCLOAK_ADMIN_PASSWORD=changeme # Configuration CORS pour production ENV QUARKUS_HTTP_CORS_ORIGINS=https://user-manager.lions.dev,https://admin.lions.dev ENV QUARKUS_HTTP_CORS_ALLOW_CREDENTIALS=true # Installer curl pour les health checks USER root RUN microdnf install curl -y && microdnf clean all RUN mkdir -p /app/logs && chown -R 185:185 /app/logs USER 185 # Copier l'application depuis le builder COPY --from=builder --chown=185 /app/target/quarkus-app/lib/ /deployments/lib/ COPY --from=builder --chown=185 /app/target/quarkus-app/*.jar /deployments/ COPY --from=builder --chown=185 /app/target/quarkus-app/app/ /deployments/app/ COPY --from=builder --chown=185 /app/target/quarkus-app/quarkus/ /deployments/quarkus/ # Exposer le port EXPOSE 8080 # Variables JVM optimisées pour production avec sécurité ENV JAVA_OPTS="-Xmx1g -Xms512m \ -XX:+UseG1GC \ -XX:MaxGCPauseMillis=200 \ -XX:+UseStringDeduplication \ -XX:+ParallelRefProcEnabled \ -XX:+HeapDumpOnOutOfMemoryError \ -XX:HeapDumpPath=/app/logs/heapdump.hprof \ -Djava.security.egd=file:/dev/./urandom \ -Djava.awt.headless=true \ -Dfile.encoding=UTF-8 \ -Djava.util.logging.manager=org.jboss.logmanager.LogManager \ -Dquarkus.profile=${QUARKUS_PROFILE}" # Point d'entrée avec profil production ENTRYPOINT ["sh", "-c", "exec java $JAVA_OPTS -jar /deployments/quarkus-run.jar"] # Health check HEALTHCHECK --interval=30s --timeout=10s --start-period=60s --retries=3 \ CMD curl -f http://localhost:8080/q/health/ready || exit 1