Lots of tweaks and traefik support, still some weirdness building.

This commit is contained in:
Vivianne 2023-01-17 00:16:56 -05:00
parent d732ec6e32
commit 16f733b47f
5 changed files with 205 additions and 16 deletions

View File

@ -14,7 +14,7 @@ server {
index index.html index.htm index.php; index index.html index.htm index.php;
charset utf-8; charset utf-8;
client_max_body_size 32M; # or your desired limit client_max_body_size 125M; # or your desired limit
location / { location / {
try_files $uri $uri/ /index.php?$query_string; try_files $uri $uri/ /index.php?$query_string;

View File

@ -0,0 +1,92 @@
FROM php:7.4-fpm-buster
# Use the default production configuration
COPY contrib/docker/php.production.ini "$PHP_INI_DIR/php.ini"
# Install Composer
ENV COMPOSER_VERSION 2.4.2
ENV COMPOSER_HOME /var/www/.composer
RUN curl -o /tmp/composer-setup.php https://getcomposer.org/installer \
&& curl -o /tmp/composer-setup.sig https://composer.github.io/installer.sig \
&& php -r "if (hash('SHA384', file_get_contents('/tmp/composer-setup.php')) !== trim(file_get_contents('/tmp/composer-setup.sig'))) { unlink('/tmp/composer-setup.php'); echo 'Invalid installer' . PHP_EOL; exit(1); }" \
&& php /tmp/composer-setup.php --no-ansi --install-dir=/usr/local/bin --filename=composer --version=${COMPOSER_VERSION} && rm -rf /tmp/composer-setup.php
# Update OS Packages
RUN apt-get update
# Install OS Packages
RUN apt-get install -y --no-install-recommends apt-utils
RUN apt-get install -y --no-install-recommends \
## Standard
locales locales-all \
git \
gosu \
zip \
unzip \
libzip-dev \
libcurl4-openssl-dev \
## Image Optimization
optipng \
pngquant \
jpegoptim \
gifsicle \
## Image Processing
libjpeg62-turbo-dev \
libpng-dev \
# Required for GD
libxpm4 \
libxpm-dev \
libwebp6 \
libwebp-dev \
## Video Processing
ffmpeg
# Update Local data
RUN sed -i '/en_US/s/^#//g' /etc/locale.gen && locale-gen && update-locale
# Install PHP extensions
RUN docker-php-source extract
#PHP Imagemagick extensions
RUN apt-get install -y --no-install-recommends libmagickwand-dev
RUN pecl install imagick
RUN docker-php-ext-enable imagick
# PHP GD extensions
RUN docker-php-ext-configure gd \
--with-freetype \
--with-jpeg \
--with-webp \
--with-xpm
RUN docker-php-ext-install -j$(nproc) gd
#PHP Redis extensions
RUN pecl install redis
RUN docker-php-ext-enable redis
#PHP Database extensions
RUN apt-get install -y --no-install-recommends libpq-dev libsqlite3-dev
RUN docker-php-ext-install pdo_mysql pdo_pgsql pdo_sqlite
#PHP extensions (dependencies)
RUN docker-php-ext-configure intl
RUN docker-php-ext-install -j$(nproc) intl bcmath zip pcntl exif curl
#Cleanup
RUN docker-php-source delete
RUN apt-get autoremove --purge -y
RUN rm -rf /var/cache/apt
RUN rm -rf /var/lib/apt/lists/*
ENV PATH="~/.composer/vendor/bin:./vendor/bin:${PATH}"
COPY . /var/www/
WORKDIR /var/www/
RUN cp -r storage storage.skel
RUN composer install --prefer-dist --no-interaction --no-ansi --optimize-autoloader
RUN rm -rf html && ln -s public html
VOLUME /var/www/storage /var/www/bootstrap
CMD ["/var/www/contrib/docker/start.fpm.sh"]

View File

@ -0,0 +1,94 @@
FROM php:7.4-buster
# Use the default production configuration
COPY contrib/docker/php.production.ini "$PHP_INI_DIR/php.ini"
# Install Composer
ENV COMPOSER_VERSION 1.9.2
ENV COMPOSER_HOME /var/www/.composer
RUN curl -o /tmp/composer-setup.php https://getcomposer.org/installer \
&& curl -o /tmp/composer-setup.sig https://composer.github.io/installer.sig \
&& php -r "if (hash('SHA384', file_get_contents('/tmp/composer-setup.php')) !== trim(file_get_contents('/tmp/composer-setup.sig'))) { unlink('/tmp/composer-setup.php'); echo 'Invalid installer' . PHP_EOL; exit(1); }" \
&& php /tmp/composer-setup.php --no-ansi --install-dir=/usr/local/bin --filename=composer --version=${COMPOSER_VERSION} && rm -rf /tmp/composer-setup.php
# Update OS Packages
RUN apt-get update
# Install OS Packages
RUN apt-get install -y --no-install-recommends apt-utils
RUN apt-get install -y --no-install-recommends \
## Standard
locales locales-all \
git \
gosu \
zip \
unzip \
libzip-dev \
libcurl4-openssl-dev \
## Image Optimization
optipng \
pngquant \
jpegoptim \
gifsicle \
## Image Processing
libjpeg62-turbo-dev \
libpng-dev \
# Required for GD
libxpm4 \
libxpm-dev \
libwebp6 \
libwebp-dev \
## Video Processing
ffmpeg
# Update Local data
RUN sed -i '/en_US/s/^#//g' /etc/locale.gen && locale-gen && update-locale
# Install PHP extensions
RUN docker-php-source extract
#PHP Imagemagick extensions
RUN apt-get install -y --no-install-recommends libmagickwand-dev
RUN pecl install imagick
RUN docker-php-ext-enable imagick
# PHP GD extensions
RUN docker-php-ext-configure gd \
--with-freetype \
--with-jpeg \
--with-webp \
--with-xpm
RUN docker-php-ext-install -j$(nproc) gd
#PHP Redis extensions
RUN pecl install redis
RUN docker-php-ext-enable redis
#PHP Database extensions
RUN apt-get install -y --no-install-recommends libpq-dev libsqlite3-dev
RUN docker-php-ext-install pdo_mysql pdo_pgsql pdo_sqlite
#PHP extensions (dependencies)
RUN docker-php-ext-configure intl
RUN docker-php-ext-install -j$(nproc) intl bcmath zip pcntl exif curl
#Cleanup
RUN docker-php-source delete
RUN apt-get autoremove --purge -y
RUN rm -rf /var/cache/apt
RUN rm -rf /var/lib/apt/lists/*
ENV PATH="~/.composer/vendor/bin:./vendor/bin:${PATH}"
COPY . /var/www/
WORKDIR /var/www/
RUN cp -r storage storage.skel
RUN composer global require hirak/prestissimo --no-interaction --no-suggest --prefer-dist
RUN composer install --prefer-dist --no-interaction --no-ansi --optimize-autoloader
RUN composer global remove hirak/prestissimo
RUN rm -rf html && ln -s public html
VOLUME /var/www/storage /var/www/bootstrap
CMD ["/var/www/contrib/docker/start.php.sh"]

View File

@ -3,6 +3,7 @@
rm -rf /var/www/public/storage rm -rf /var/www/public/storage
ln -s /var/www/storage/app/public /var/www/public/storage ln -s /var/www/storage/app/public /var/www/public/storage
chown -R www-data /var/www/public/ # nginx user inside container
chown -R 101:101 /var/www/public/
./docker-entrypoint.sh nginx -g "daemon off;" ./docker-entrypoint.sh nginx -g "daemon off;"

View File

@ -17,14 +17,13 @@ services:
build: build:
context: . context: .
dockerfile: contrib/docker/Dockerfile.fpm dockerfile: contrib/docker/Dockerfile.fpm
image: porttown.solarpunk.moe/pixelfed # image: git.solarpunk.moe/pixelfed
restart: unless-stopped restart: unless-stopped
env_file: env_file:
- .env.docker - .env.docker
volumes: volumes:
- app-storage:/var/www/storage - app-storage:/var/www/storage
- app-bootstrap:/var/www/bootstrap - app-bootstrap:/var/www/bootstrap
- "./.env.docker:/var/www/.env"
networks: networks:
internal: internal:
external: external:
@ -38,7 +37,7 @@ services:
build: build:
context: . context: .
dockerfile: contrib/docker/Dockerfile.fpm dockerfile: contrib/docker/Dockerfile.fpm
image: porttown.solarpunk.moe/pixelfed #image: git.solarpunk.moe/pixelfed
restart: unless-stopped restart: unless-stopped
env_file: env_file:
- .env.docker - .env.docker
@ -46,8 +45,8 @@ services:
- app-storage:/var/www/storage - app-storage:/var/www/storage
- app-bootstrap:/var/www/bootstrap - app-bootstrap:/var/www/bootstrap
networks: networks:
- internal internal:
- mail mail:
command: gosu www-data php artisan horizon command: gosu www-data php artisan horizon
depends_on: depends_on:
- db - db
@ -58,12 +57,12 @@ services:
image: mysql:8.0 image: mysql:8.0
restart: unless-stopped restart: unless-stopped
networks: networks:
- internal internal:
command: --default-authentication-plugin=mysql_native_password command: --default-authentication-plugin=mysql_native_password
env_file: env_file:
- .env.docker - .env.docker
volumes: volumes:
- "db-data:/var/lib/lib/mysql" - "db-data:/var/lib/mysql"
redis: redis:
image: redis:5-alpine image: redis:5-alpine
@ -73,24 +72,28 @@ services:
volumes: volumes:
- "redis-data:/data" - "redis-data:/data"
networks: networks:
- internal internal:
nginx: nginx:
image: nginx image: nginx
restart: always restart: always
command: /var/www/start.nginx.sh command: /var/www/start.nginx.sh
networks: networks:
- httpsproxy httpsproxy:
- external external:
volumes: volumes:
- ./contrib/docker-nginx.conf:/etc/nginx/templates/default.conf.template - ./contrib/docker-nginx.conf:/etc/nginx/templates/default.conf.template
- ./contrib/docker/start.nginx.sh:/var/www/start.nginx.sh - ./contrib/docker/start.nginx.sh:/var/www/start.nginx.sh
- ./public:/var/www/public - ./public:/var/www/public
- app-storage:/var/www/storage - app-storage:/var/www/storage
labels:
- "traefik.enable=true"
- "traefik.http.services.pixelfed.loadbalancer.server.port=80"
- "traefik.http.routers.pixelfed.rule=Host(`pix.solarpunk.moe`)"
- "traefik.http.routers.pixelfed.tls.certresolver=leresolver"
- "traefik.http.routers.pixelfed.entrypoints=websecure"
environment: environment:
- LETSENCRYPT_HOST=pix.solarpunk.moe
- VIRTUAL_HOST=pix.solarpunk.moe
- VIRTUAL_PORT=80
- NGINX_PORT=80 - NGINX_PORT=80
volumes: volumes:
@ -101,7 +104,6 @@ volumes:
networks: networks:
internal: internal:
internal: true
external: external:
mail: mail:
external: true external: true