Fix: Solucionados problemas de permisos en Docker y agregada gestion de Webhook de Telegram
This commit is contained in:
57
Dockerfile
57
Dockerfile
@@ -1,26 +1,15 @@
|
||||
# ============================================
|
||||
# Laravel PHP-FPM 8.3 - Production Optimized
|
||||
# Laravel - Single Image (Nginx + PHP-FPM)
|
||||
# ============================================
|
||||
|
||||
# Stage 1: Builder with Composer
|
||||
FROM composer:2 AS composer-builder
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Copy composer files first for better layer caching
|
||||
COPY composer.json composer.lock* ./
|
||||
RUN composer install --no-dev --optimize-autoloader --no-interaction --prefer-dist
|
||||
|
||||
# Stage 2: PHP-FPM Production Image
|
||||
FROM php:8.3-fpm-bookworm
|
||||
|
||||
# Build arguments for dynamic user UID/GID
|
||||
ARG PUID=1000
|
||||
ARG PGID=1000
|
||||
|
||||
# Labels
|
||||
LABEL maintainer="dev@local.dev" \
|
||||
description="Laravel PHP-FPM 8.3 production container"
|
||||
description="Laravel single container with Nginx"
|
||||
|
||||
# Install system dependencies
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
@@ -37,6 +26,7 @@ RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
libsqlite3-dev \
|
||||
unzip \
|
||||
git \
|
||||
nginx \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# Install PHP extensions
|
||||
@@ -59,48 +49,43 @@ RUN echo "opcache.enable=1" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.
|
||||
&& echo "opcache.revalidate_freq=2" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini \
|
||||
&& echo "opcache.fast_shutdown=1" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini \
|
||||
&& echo "upload_max_filesize=100M" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini \
|
||||
&& echo "post_max_size=100M" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini
|
||||
&& echo "post_max_size=100M" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini \
|
||||
&& echo "listen = 0.0.0.0:9000" >> /usr/local/etc/php-fpm.d/www.conf \
|
||||
&& sed -i 's/user = www-data/user = laravel/g' /usr/local/etc/php-fpm.d/www.conf \
|
||||
&& sed -i 's/group = www-data/group = laravel/g' /usr/local/etc/php-fpm.d/www.conf \
|
||||
&& echo "sys_temp_dir = /tmp" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini \
|
||||
&& echo "upload_tmp_dir = /tmp" >> /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini
|
||||
|
||||
# Copy Composer from builder stage
|
||||
COPY --from=composer-builder /usr/bin/composer /usr/bin/composer
|
||||
COPY --from=composer-builder /root/.composer /root/.composer
|
||||
|
||||
# Create Laravel storage directories with proper permissions
|
||||
# Create Laravel storage directories
|
||||
RUN mkdir -p /var/www/html/storage/framework/{cache,sessions,views} \
|
||||
&& mkdir -p /var/www/html/storage/logs \
|
||||
&& mkdir -p /var/www/html/bootstrap/cache \
|
||||
&& chmod -R 775 /var/www/html/storage \
|
||||
&& chmod -R 775 /var/www/html/bootstrap/cache
|
||||
|
||||
# Create system user for Laravel (dynamic UID/GID)
|
||||
# Create system user for Laravel
|
||||
RUN groupadd -g ${PGID} laravel && \
|
||||
useradd -u ${PUID} -g laravel -m -s /bin/bash laravel
|
||||
|
||||
# Set working directory
|
||||
# Copy nginx config
|
||||
COPY docker/nginx/nginx.conf /etc/nginx/sites-available/default
|
||||
|
||||
WORKDIR /var/www/html
|
||||
|
||||
# Copy application files
|
||||
COPY --chown=laravel:laravel . /var/www/html
|
||||
|
||||
# Fix storage permissions
|
||||
# Fix permissions
|
||||
RUN chown -R laravel:laravel /var/www/html/storage \
|
||||
&& chown -R laravel:laravel /var/www/html/bootstrap/cache \
|
||||
&& chmod -R 775 /var/www/html/storage \
|
||||
&& chmod -R 775 /var/www/html/bootstrap/cache
|
||||
|
||||
# Switch to non-root user
|
||||
USER laravel
|
||||
# Copy entrypoint
|
||||
COPY --chown=root:root docker/entrypoint.sh /entrypoint.sh
|
||||
RUN chmod +x /entrypoint.sh
|
||||
|
||||
# Expose port 9000 (PHP-FPM)
|
||||
EXPOSE 9000
|
||||
# Expose port 80 (interno)
|
||||
EXPOSE 80
|
||||
|
||||
# Health check
|
||||
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
|
||||
CMD php-fpm-healthcheck || exit 1
|
||||
|
||||
# Create healthcheck script
|
||||
RUN echo '#!/bin/sh' > /usr/local/bin/php-fpm-healthcheck \
|
||||
&& echo 'SCRIPT_NAME=/health.php SCRIPT_FILENAME=/health.php REQUEST_METHOD=GET cgi-fcgi -bind -connect 127.0.0.1:9000 > /dev/null 2>&1' >> /usr/local/bin/php-fpm-healthcheck \
|
||||
&& chmod +x /usr/local/bin/php-fpm-healthcheck
|
||||
|
||||
CMD ["php-fpm"]
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
Reference in New Issue
Block a user