Lots of tweaks and traefik support, still some weirdness building.
This commit is contained in:
parent
d732ec6e32
commit
16f733b47f
|
@ -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;
|
||||||
|
|
|
@ -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"]
|
|
@ -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"]
|
|
@ -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;"
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue