Initial Commit
parent
1a74d0d3b3
commit
a192de501a
@ -0,0 +1,137 @@
|
||||
version: '3'
|
||||
|
||||
networks:
|
||||
rauru_net:
|
||||
|
||||
volumes:
|
||||
local_pgdata_rauru:
|
||||
pgadmin-data:
|
||||
|
||||
services:
|
||||
app:
|
||||
container_name: rauru_app
|
||||
build:
|
||||
context: ./dockerfiles
|
||||
dockerfile: nginx.dockerfile
|
||||
args:
|
||||
- UID=${UID:-1000}
|
||||
- GID=${GID:-1000}
|
||||
ports:
|
||||
- "80:80"
|
||||
volumes:
|
||||
- ./src:/var/www/html:delegated
|
||||
depends_on:
|
||||
- php
|
||||
- redis
|
||||
- db
|
||||
- mailhog
|
||||
- pgadmin
|
||||
networks:
|
||||
- rauru_net
|
||||
db:
|
||||
image: postgres
|
||||
container_name: rauru_db
|
||||
ports:
|
||||
- "5432:5432"
|
||||
environment:
|
||||
POSTGRES_DB: rauru_db
|
||||
POSTGRES_USER: rauru_user
|
||||
POSTGRES_PASSWORD: secret
|
||||
volumes:
|
||||
- local_pgdata_rauru:/var/lib/postgresql/data
|
||||
#- ./rauru_pgdata:/var/lib/postgresql/data
|
||||
networks:
|
||||
- rauru_net
|
||||
pgadmin:
|
||||
image: dpage/pgadmin4
|
||||
container_name: rauru_pgAdmin
|
||||
ports:
|
||||
- "5050:80"
|
||||
depends_on:
|
||||
- db
|
||||
environment:
|
||||
PGADMIN_DEFAULT_EMAIL: admin@example.de
|
||||
PGADMIN_DEFAULT_PASSWORD: secret
|
||||
volumes:
|
||||
- pgadmin-data:/var/lib/pgadmin
|
||||
#- ./pgadmindata:/var/lib/pgadmin
|
||||
networks:
|
||||
- rauru_net
|
||||
php:
|
||||
build:
|
||||
context: ./dockerfiles
|
||||
dockerfile: php.root.dockerfile
|
||||
args:
|
||||
- UID=${UID:-1000}
|
||||
- GID=${GID:-1000}
|
||||
container_name: rauru_php
|
||||
ports:
|
||||
- "9000:9000"
|
||||
volumes:
|
||||
- ./src:/var/www/html:delegated
|
||||
networks:
|
||||
- rauru_net
|
||||
|
||||
redis:
|
||||
image: redis:alpine
|
||||
container_name: rauru_redis
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "6379:6379"
|
||||
networks:
|
||||
- rauru_net
|
||||
|
||||
composer:
|
||||
build:
|
||||
context: ./dockerfiles
|
||||
dockerfile: php.root.dockerfile
|
||||
args:
|
||||
- UID=${UID:-1000}
|
||||
- GID=${GID:-1000}
|
||||
container_name: rauru_composer
|
||||
volumes:
|
||||
- ./src:/var/www/html
|
||||
depends_on:
|
||||
- php
|
||||
entrypoint: [ 'composer', '--ignore-platform-reqs' ]
|
||||
networks:
|
||||
- rauru_net
|
||||
|
||||
npm:
|
||||
image: node:current-alpine
|
||||
container_name: rauru_npm
|
||||
volumes:
|
||||
- ./src:/var/www/html
|
||||
ports:
|
||||
- "3000:3000"
|
||||
- "3001:3001"
|
||||
- "5173:5173"
|
||||
working_dir: /var/www/html
|
||||
entrypoint: [ 'npm' ]
|
||||
networks:
|
||||
- rauru_net
|
||||
|
||||
artisan:
|
||||
build:
|
||||
context: ./dockerfiles
|
||||
dockerfile: php.root.dockerfile
|
||||
args:
|
||||
- UID=${UID:-1000}
|
||||
- GID=${GID:-1000}
|
||||
container_name: rauru_artisan
|
||||
volumes:
|
||||
- ./src:/var/www/html:delegated
|
||||
depends_on:
|
||||
- db
|
||||
entrypoint: [ 'php', '/var/www/html/artisan' ]
|
||||
networks:
|
||||
- rauru_net
|
||||
|
||||
mailhog:
|
||||
container_name: rauru_mailhog
|
||||
image: mailhog/mailhog:latest
|
||||
ports:
|
||||
- "1025:1025"
|
||||
- "8025:8025"
|
||||
networks:
|
||||
- rauru_net
|
@ -0,0 +1,18 @@
|
||||
FROM nginx:stable-alpine
|
||||
|
||||
ARG UID
|
||||
ARG GID
|
||||
|
||||
ENV UID=${UID}
|
||||
ENV GID=${GID}
|
||||
|
||||
# MacOS staff group's gid is 20, so is the dialout group in alpine linux. We're not using it, let's just remove it.
|
||||
RUN delgroup dialout
|
||||
|
||||
RUN addgroup -g ${GID} --system laravel
|
||||
RUN adduser -G laravel --system -D -s /bin/sh -u ${UID} laravel
|
||||
RUN sed -i "s/user nginx/user laravel/g" /etc/nginx/nginx.conf
|
||||
|
||||
ADD ./nginx/default.conf /etc/nginx/conf.d/
|
||||
|
||||
RUN mkdir -p /var/www/html
|
@ -0,0 +1,20 @@
|
||||
server {
|
||||
listen 80;
|
||||
index index.php index.html;
|
||||
server_name _;
|
||||
root /var/www/html/public;
|
||||
|
||||
location / {
|
||||
try_files $uri $uri/ /index.php?$query_string;
|
||||
}
|
||||
|
||||
location ~ \.php$ {
|
||||
try_files $uri =404;
|
||||
fastcgi_split_path_info ^(.+\.php)(/.+)$;
|
||||
fastcgi_pass php:9000;
|
||||
fastcgi_index index.php;
|
||||
include fastcgi_params;
|
||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||
fastcgi_param PATH_INFO $fastcgi_path_info;
|
||||
}
|
||||
}
|
@ -0,0 +1,38 @@
|
||||
FROM php:8-fpm-alpine
|
||||
|
||||
ARG UID
|
||||
ARG GID
|
||||
|
||||
ENV UID=${UID}
|
||||
ENV GID=${GID}
|
||||
|
||||
RUN mkdir -p /var/www/html
|
||||
|
||||
WORKDIR /var/www/html
|
||||
|
||||
COPY --from=composer:latest /usr/bin/composer /usr/local/bin/composer
|
||||
|
||||
# MacOS staff group's gid is 20, so is the dialout group in alpine linux. We're not using it, let's just remove it.
|
||||
RUN delgroup dialout
|
||||
|
||||
RUN addgroup -g ${GID} --system laravel
|
||||
RUN adduser -G laravel --system -D -s /bin/sh -u ${UID} laravel
|
||||
|
||||
RUN sed -i "s/user = www-data/user = laravel/g" /usr/local/etc/php-fpm.d/www.conf
|
||||
RUN sed -i "s/group = www-data/group = laravel/g" /usr/local/etc/php-fpm.d/www.conf
|
||||
RUN echo "php_admin_flag[log_errors] = on" >> /usr/local/etc/php-fpm.d/www.conf
|
||||
|
||||
RUN set -ex \
|
||||
&& apk --no-cache add \
|
||||
postgresql-dev
|
||||
|
||||
RUN docker-php-ext-install pdo pdo_mysql pdo_pgsql
|
||||
|
||||
RUN mkdir -p /usr/src/php/ext/redis \
|
||||
&& curl -L https://github.com/phpredis/phpredis/archive/5.3.4.tar.gz | tar xvz -C /usr/src/php/ext/redis --strip 1 \
|
||||
&& echo 'redis' >> /usr/src/php-available-exts \
|
||||
&& docker-php-ext-install redis
|
||||
|
||||
USER laravel
|
||||
|
||||
CMD ["php-fpm", "-y", "/usr/local/etc/php-fpm.conf", "-R"]
|
@ -0,0 +1,26 @@
|
||||
FROM php:8-fpm-alpine
|
||||
|
||||
RUN mkdir -p /var/www/html
|
||||
|
||||
WORKDIR /var/www/html
|
||||
|
||||
COPY --from=composer:latest /usr/bin/composer /usr/local/bin/composer
|
||||
|
||||
RUN sed -i "s/user = www-data/user = root/g" /usr/local/etc/php-fpm.d/www.conf
|
||||
RUN sed -i "s/group = www-data/group = root/g" /usr/local/etc/php-fpm.d/www.conf
|
||||
RUN echo "php_admin_flag[log_errors] = on" >> /usr/local/etc/php-fpm.d/www.conf
|
||||
|
||||
RUN set -ex \
|
||||
&& apk --no-cache add \
|
||||
postgresql-dev
|
||||
|
||||
RUN docker-php-ext-install pdo pdo_mysql pdo_pgsql
|
||||
|
||||
RUN mkdir -p /usr/src/php/ext/redis \
|
||||
&& curl -L https://github.com/phpredis/phpredis/archive/5.3.4.tar.gz | tar xvz -C /usr/src/php/ext/redis --strip 1 \
|
||||
&& echo 'redis' >> /usr/src/php-available-exts \
|
||||
&& docker-php-ext-install redis
|
||||
|
||||
USER root
|
||||
|
||||
CMD ["php-fpm", "-y", "/usr/local/etc/php-fpm.conf", "-R"]
|
Loading…
Reference in New Issue