Docker updates
This commit is contained in:
@ -1,6 +1,5 @@
|
||||
APP_ENV = "docker"
|
||||
DOCKER_APP_PORT = 8000
|
||||
DOCKER_DB_PORT = 3306
|
||||
DOCKER_DB_USERNAME = dbadmin
|
||||
DOCKER_DB_PASSWORD = secret
|
||||
DB_DATABASE = ttp
|
||||
DOCKER_DB_DATABASE = ttp
|
@ -1,11 +0,0 @@
|
||||
FROM nginx:latest as nginx
|
||||
|
||||
FROM php:8-fpm as php-fpm
|
||||
RUN apt-get update -y
|
||||
RUN apt-get install -y libmariadb-dev
|
||||
RUN docker-php-ext-install mysqli pdo pdo_mysql
|
||||
|
||||
FROM php:8-apache as apache
|
||||
RUN a2enmod ssl && a2enmod rewrite
|
||||
RUN docker-php-ext-install mysqli pdo pdo_mysql
|
||||
WORKDIR /var/www/html
|
@ -1,11 +0,0 @@
|
||||
ServerName localhost
|
||||
<VirtualHost *:80>
|
||||
ServerAdmin admin@localhost
|
||||
DocumentRoot /var/www/html/
|
||||
<Directory /var/www/html/>
|
||||
DirectoryIndex index.php
|
||||
Options Indexes FollowSymLinks
|
||||
AllowOverride All
|
||||
Require all granted
|
||||
</Directory>
|
||||
</VirtualHost>
|
@ -1,73 +0,0 @@
|
||||
server {
|
||||
listen 80 default_server;
|
||||
index index.php;
|
||||
server_name TheTempusProject;
|
||||
error_log /var/www/html/logs/nginx-error.log;
|
||||
access_log /var/www/html/logs/nginx-access.log;
|
||||
root /var/www/html;
|
||||
charset utf-8;
|
||||
sendfile off;
|
||||
client_max_body_size 100m;
|
||||
|
||||
location /js/ {
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
try_files $uri /index.php?error=js404&file=$uri;
|
||||
}
|
||||
|
||||
location /css/ {
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
try_files $uri /index.php?error=css404&file=$uri;
|
||||
}
|
||||
|
||||
location /images/ {
|
||||
try_files $uri /index.php?error=image404&url=$uri;
|
||||
}
|
||||
|
||||
location /uploads/ {
|
||||
try_files $uri /index.php?error=upload404&url=$uri;
|
||||
}
|
||||
|
||||
location /errors/ {
|
||||
try_files $uri /index.php?error=$uri;
|
||||
}
|
||||
|
||||
location ~* \.(?:js|css|png|jpg|gif|ico)$ {
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
}
|
||||
|
||||
location = /favicon.ico {
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
rewrite ^(.+)$ /images/favicon.ico break;
|
||||
}
|
||||
|
||||
location = /robots.txt {
|
||||
allow all;
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
rewrite ^(.+)$ /bin/robots.txt break;
|
||||
}
|
||||
|
||||
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;
|
||||
fastcgi_intercept_errors off;
|
||||
fastcgi_buffer_size 16k;
|
||||
fastcgi_buffers 4 16k;
|
||||
fastcgi_connect_timeout 60s;
|
||||
fastcgi_read_timeout 60s;
|
||||
fastcgi_send_timeout 60s;
|
||||
}
|
||||
|
||||
location / {
|
||||
rewrite ^/(.+)$ /index.php?url=$1&$args last;
|
||||
}
|
||||
}
|
13
docker/ttp-apache/Dockerfile
Normal file
13
docker/ttp-apache/Dockerfile
Normal file
@ -0,0 +1,13 @@
|
||||
FROM php:8-apache as apache
|
||||
ENV COMPOSER_ALLOW_SUPERUSER=1
|
||||
RUN apt-get update -y
|
||||
RUN apt-get install git libzip-dev -y
|
||||
RUN a2enmod ssl && a2enmod rewrite
|
||||
RUN docker-php-ext-install mysqli pdo pdo_mysql zip
|
||||
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
|
||||
# RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
|
||||
WORKDIR /var/www
|
||||
RUN rm -rf html/
|
||||
RUN composer create-project thetempusproject/thetempusproject html
|
||||
RUN chmod -R 777 html/
|
||||
RUN chown -R www-data:www-data html/
|
19
docker/ttp-apache/README.md
Normal file
19
docker/ttp-apache/README.md
Normal file
@ -0,0 +1,19 @@
|
||||
Build the image
|
||||
```
|
||||
docker build -t thetempusproject/ttp-apache:latest .
|
||||
docker build --no-cache -t thetempusproject/ttp-apache:latest .
|
||||
```
|
||||
|
||||
|
||||
|
||||
Set the proper tag for dockerhub
|
||||
```
|
||||
docker tag ttp-apache:latest thetempusproject/ttp-apache:latest
|
||||
```
|
||||
|
||||
|
||||
|
||||
Run the image
|
||||
```
|
||||
docker run -d -p 80:80 thetempusproject/ttp-apache
|
||||
```
|
29
docker/ttp-nginx/Dockerfile
Normal file
29
docker/ttp-nginx/Dockerfile
Normal file
@ -0,0 +1,29 @@
|
||||
FROM php:8-fpm as php-fpm
|
||||
|
||||
# Env
|
||||
ENV COMPOSER_ALLOW_SUPERUSER=1
|
||||
|
||||
# Install Packages
|
||||
RUN apt-get update -y
|
||||
RUN apt-get install -y nginx libmariadb-dev git libzip-dev zip unzip supervisor
|
||||
RUN docker-php-ext-install mysqli pdo pdo_mysql zip
|
||||
|
||||
# Install Composer
|
||||
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
|
||||
|
||||
#Install TTP
|
||||
WORKDIR /var/www
|
||||
RUN rm -rf html/
|
||||
RUN composer create-project thetempusproject/thetempusproject html
|
||||
RUN chmod -R 777 html/
|
||||
RUN chown -R www-data:www-data html/
|
||||
|
||||
# Copy Nginx configuration file
|
||||
RUN cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.old
|
||||
COPY ./docker/ttp-nginx/nginx.conf /etc/nginx/nginx.conf
|
||||
|
||||
# Copy Supervisor configuration file
|
||||
COPY ./docker/ttp-nginx/supervisord.conf /etc/supervisor/conf.d/supervisord.conf
|
||||
|
||||
# Start Supervisor, which will start both Nginx and PHP-FPM
|
||||
CMD ["/usr/bin/supervisord", "-c", "/etc/supervisor/conf.d/supervisord.conf"]
|
19
docker/ttp-nginx/README.md
Normal file
19
docker/ttp-nginx/README.md
Normal file
@ -0,0 +1,19 @@
|
||||
Build the image
|
||||
```
|
||||
docker build -t thetempusproject/ttp-nginx:latest .
|
||||
docker build --no-cache -t thetempusproject/ttp-nginx:latest .
|
||||
```
|
||||
|
||||
|
||||
|
||||
Set the proper tag for dockerhub
|
||||
```
|
||||
docker tag ttp-nginx:latest thetempusproject/ttp-nginx:latest
|
||||
```
|
||||
|
||||
|
||||
|
||||
Run the image
|
||||
```
|
||||
docker run -d -p 8000:80 thetempusproject/ttp-nginx
|
||||
```
|
90
docker/ttp-nginx/nginx.conf
Normal file
90
docker/ttp-nginx/nginx.conf
Normal file
@ -0,0 +1,90 @@
|
||||
user www-data;
|
||||
worker_processes auto;
|
||||
pid /run/nginx.pid;
|
||||
error_log /var/log/nginx/error.log;
|
||||
include /etc/nginx/modules-enabled/*.conf;
|
||||
|
||||
events {
|
||||
worker_connections 768;
|
||||
}
|
||||
|
||||
http {
|
||||
tcp_nopush on;
|
||||
types_hash_max_size 2048;
|
||||
include /etc/nginx/mime.types;
|
||||
default_type application/octet-stream;
|
||||
ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3; # Dropping SSLv3, ref: POODLE
|
||||
ssl_prefer_server_ciphers on;
|
||||
|
||||
access_log /var/log/nginx/access.log;
|
||||
|
||||
gzip on;
|
||||
server {
|
||||
listen 80 default_server;
|
||||
index index.php;
|
||||
server_name TheTempusProject;
|
||||
root /var/www/html;
|
||||
charset utf-8;
|
||||
sendfile on;
|
||||
client_max_body_size 100m;
|
||||
|
||||
location /js/ {
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
try_files $uri /index.php?error=js404&file=$uri;
|
||||
}
|
||||
|
||||
location /css/ {
|
||||
try_files $uri /index.php?error=css404&file=$uri;
|
||||
}
|
||||
|
||||
location /images/ {
|
||||
try_files $uri /index.php?error=image404&url=$uri;
|
||||
}
|
||||
|
||||
location /uploads/ {
|
||||
try_files $uri /index.php?error=upload404&url=$uri;
|
||||
}
|
||||
|
||||
location /errors/ {
|
||||
try_files $uri /index.php?error=$uri;
|
||||
}
|
||||
|
||||
location = /favicon.ico {
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
rewrite ^(.+)$ /images/favicon.ico break;
|
||||
}
|
||||
|
||||
location = /robots.txt {
|
||||
allow all;
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
rewrite ^(.+)$ /bin/robots.txt break;
|
||||
}
|
||||
|
||||
location ~* \.(?:js|css|png|jpg|gif|ico)$ {
|
||||
access_log off;
|
||||
log_not_found off;
|
||||
}
|
||||
|
||||
location ~ \.php$ {
|
||||
fastcgi_pass 127.0.0.1:9000;
|
||||
include snippets/fastcgi-php.conf;
|
||||
include fastcgi_params;
|
||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||
fastcgi_intercept_errors off;
|
||||
fastcgi_buffer_size 16k;
|
||||
fastcgi_buffers 4 16k;
|
||||
fastcgi_connect_timeout 60s;
|
||||
fastcgi_read_timeout 60s;
|
||||
fastcgi_send_timeout 60s;
|
||||
}
|
||||
|
||||
location / {
|
||||
rewrite ^/(.+)$ /index.php?url=$1&$args last;
|
||||
}
|
||||
}
|
||||
|
||||
include /etc/nginx/conf.d/*.conf;
|
||||
}
|
8
docker/ttp-nginx/supervisord.conf
Normal file
8
docker/ttp-nginx/supervisord.conf
Normal file
@ -0,0 +1,8 @@
|
||||
[supervisord]
|
||||
nodaemon=true
|
||||
|
||||
[program:php-fpm]
|
||||
command=/usr/local/sbin/php-fpm
|
||||
|
||||
[program:nginx]
|
||||
command=/usr/sbin/nginx -g 'daemon off;'
|
Reference in New Issue
Block a user