Files
laravel-php-fpm/README.md

248 lines
5.9 KiB
Markdown
Raw Normal View History

2023-01-04 17:40:44 +02:00
[![Build](https://github.com/jkaninda/laravel-php-fpm/actions/workflows/build.yml/badge.svg)](https://github.com/jkaninda/laravel-php-fpm/actions/workflows/build.yml)
2023-12-09 18:25:28 +01:00
[![Integration Test](https://github.com/jkaninda/laravel-php-fpm/actions/workflows/integration-tests.yml/badge.svg)](https://github.com/jkaninda/laravel-php-fpm/actions/workflows/integration-tests.yml)
![Docker Image Size (latest by date)](https://img.shields.io/docker/image-size/jkaninda/laravel-php-fpm?style=flat-square)
![Docker Pulls](https://img.shields.io/docker/pulls/jkaninda/laravel-php-fpm?style=flat-square)
2024-01-06 15:01:46 +01:00
<p align="center">
<a href="https://github.com/jkaninda/laravel-php-fpm">
<img src="https://raw.githubusercontent.com/laravel/art/master/logo-lockup/5%20SVG/2%20CMYK/1%20Full%20Color/laravel-logolockup-cmyk-red.svg" width="400" alt="Logo">
</a>
</p>
2022-06-17 15:16:05 +02:00
# Laravel PHP-FPM Docker image
2022-09-20 06:08:46 +02:00
> 🐳 Full Docker image for a PHP-FPM container created to run Laravel or any php based applications.
2022-11-01 10:21:59 +02:00
2023-05-29 06:58:20 +02:00
> PHP Microservices ready Docker container image.
2022-06-19 16:06:32 +02:00
- [Docker Hub](https://hub.docker.com/r/jkaninda/laravel-php-fpm)
2022-09-07 13:03:51 +02:00
- [Github](https://github.com/jkaninda/laravel-php-fpm)
2022-06-17 15:16:05 +02:00
2023-10-11 15:15:44 +02:00
## PHP Version:
- 8.3
2023-10-11 15:15:44 +02:00
- 8.2
- 8.1
- 8.0
- 7.4
- 7.2
2022-06-17 15:16:05 +02:00
## Specifications:
* Composer
* OpenSSL PHP Extension
* XML PHP Extension
* PDO PHP Extension
2022-09-27 20:07:41 +02:00
* PDO Mysql
* PDO Pgsql
2022-06-17 15:16:05 +02:00
* Rdkafka PHP Extension
* Redis PHP Extension
* Mbstring PHP Extension
* PCNTL PHP Extension
* ZIP PHP Extension
* GD PHP Extension
* BCMath PHP Extension
* Memcached
2023-09-20 05:44:00 +02:00
* Opcache
2022-06-17 15:16:05 +02:00
* Laravel Cron Job
2022-06-17 16:48:58 +02:00
* Laravel Schedule
2022-06-17 15:16:05 +02:00
* Laravel Envoy
2022-06-17 16:48:58 +02:00
* Supervisord
2022-09-05 15:08:24 +02:00
* Node
* NPM
2022-06-17 16:48:58 +02:00
## Simple docker-compose usage:
```yml
version: '3'
services:
php-fpm:
2022-06-22 03:12:07 +02:00
image: jkaninda/laravel-php-fpm:latest
2022-06-17 16:48:58 +02:00
container_name: php-fpm
restart: unless-stopped
2024-01-06 15:05:57 +01:00
user: www-data #Use www-data user for production usage
2022-06-17 16:48:58 +02:00
volumes:
#Project root
2022-06-22 03:12:07 +02:00
- ./:/var/www/html
2022-06-17 16:48:58 +02:00
networks:
- default #if you're using networks between containers
```
## Laravel `artisan` command usage:
### Open php-fpm
```sh
docker compose exec php-fpm /bin/bash
2022-06-17 16:48:58 +02:00
2023-05-29 01:36:23 +02:00
```
2023-05-29 06:58:20 +02:00
## Configurations
2022-06-17 16:48:58 +02:00
2024-01-13 14:21:30 +01:00
- Supervisor config folder: /etc/supervisor/conf.d/
- PHP ini config foler /usr/local/etc/php/conf.d/
2022-06-17 16:48:58 +02:00
## Example Laravel-php-fpm with nginx:
2022-06-19 16:06:32 +02:00
### docker-compose.yml
2022-06-17 16:48:58 +02:00
```yml
version: '3'
services:
php-fpm:
image: jkaninda/laravel-php-fpm
2022-06-17 16:48:58 +02:00
container_name: php-fpm
restart: unless-stopped
2022-06-17 16:48:58 +02:00
volumes:
#Project root
2022-06-22 03:12:07 +02:00
- ./:/var/www/html
2022-06-17 16:48:58 +02:00
networks:
- default #if you're using networks between containers
#Nginx server
nginx-server:
2022-11-01 09:56:17 +02:00
image: jkaninda/nginx-fpm:alpine
container_name: nginx-server
restart: unless-stopped
ports:
2022-06-17 16:48:58 +02:00
- 80:80
2022-11-01 09:56:17 +02:00
volumes:
2022-06-22 03:12:07 +02:00
- ./:/var/www/html
2022-11-01 09:56:17 +02:00
environment:
- DOCUMENT_ROOT=/var/www/html/public
- CLIENT_MAX_BODY_SIZE=20M
- PHP_FPM_HOST=php-fpm:9000
networks:
2022-06-17 16:48:58 +02:00
- default
```
## Simple Nginx config file content
### default.conf
2022-06-17 16:48:58 +02:00
```conf
server {
listen 80;
index index.php index.html;
error_log /var/log/nginx/error.log;
access_log /var/log/nginx/access.log;
##Public directory
2022-06-22 03:12:07 +02:00
root /var/www/html/public;
2022-06-17 16:48:58 +02:00
location ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
## PHP FPM ( php-fpm:9000 ) or [servicename:9000]
2022-06-17 16:48:58 +02:00
fastcgi_pass php-fpm:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
}
client_max_body_size 15M;
server_tokens off;
# Hide PHP headers
fastcgi_hide_header X-Powered-By;
fastcgi_hide_header X-CF-Powered-By;
fastcgi_hide_header X-Runtime;
location / {
try_files $uri $uri/ /index.php?$query_string;
gzip_static on;
}
}
2022-06-22 03:18:26 +02:00
```
2022-06-17 16:48:58 +02:00
2022-06-22 03:12:07 +02:00
## Advanced Laravel-php-fpm with nginx:
### docker-compose.yml
```yml
version: '3'
services:
php-fpm:
image: jkaninda/laravel-php-fpm
container_name: php-fpm
restart: unless-stopped
volumes:
#Project root
- ./:/var/www/html
- ~/.ssh:/root/.ssh # If you use private CVS
- ./php.ini:/usr/local/etc/php/conf.d/php.ini # Optional, your custom php init file
environment:
- APP_ENV=development # Optional, or production
2022-09-05 15:08:24 +02:00
#- LARAVEL_PROCS_NUMBER=1 # Optional, Laravel queue:work process number
2022-06-22 03:12:07 +02:00
#Nginx server
nginx-server:
image: nginx:alpine
container_name: nginx-server
restart: unless-stopped
ports:
- 80:80
volumes:
- ./:/var/www/html
- ./default.conf:/etc/nginx/conf.d/default.conf
networks:
- default
volumes:
storage-data:
2022-06-17 16:48:58 +02:00
```
2022-06-22 03:12:07 +02:00
2022-06-17 16:48:58 +02:00
## Docker run
```sh
2022-06-17 16:48:58 +02:00
docker-compose up -d
```
2023-01-04 17:40:44 +02:00
## Build from base
2023-01-04 17:40:44 +02:00
Dockerfile
```Dockerfile
2023-12-16 07:19:50 +01:00
FROM jkaninda/laravel-php-fpm:8.3
2023-01-04 17:40:44 +02:00
# Copy laravel project files
COPY . /var/www/html
# Storage Volume
VOLUME /var/www/html/storage
WORKDIR /var/www/html
2023-12-16 07:19:50 +01:00
# Custom cache invalidation / optional
#ARG CACHEBUST=1
# Run composer install / Optional
#RUN composer install
# Fix permissions
RUN chown -R www-data:www-data /var/www/html
2023-01-04 17:40:44 +02:00
```
2022-07-05 05:40:09 +02:00
## Supervisord
2023-11-13 07:21:24 +01:00
### Add supervisor process in
> /etc/supervisor/conf.d/
2023-11-13 07:22:17 +01:00
2023-11-13 15:17:41 +01:00
In case you want to execute and maintain a task or process with supervisor.
Find below an example with Apache Kafka, when you want to maintain a consumer process.
2023-11-13 07:21:24 +01:00
### Example:
```conf
[program:kafkaconsume-worker]
process_name=%(program_name)s_%(process_num)02d
command=php /var/www/html/artisan kafka:consumer
autostart=true
autorestart=true
numprocs=1
user=www-data
redirect_stderr=true
stdout_logfile=/var/www/html/storage/logs/kafka.log
```
2022-07-05 05:40:09 +02:00
2022-09-05 15:12:47 +02:00
### Custom php.ini
> /var/www/html/conf/php/php.ini
2022-09-07 13:03:51 +02:00
### Storage permision issue
2023-12-16 07:19:50 +01:00
```sh
docker compose exec php-fpm /bin/bash
2023-12-16 07:19:50 +01:00
```
2022-09-07 13:03:51 +02:00
2023-12-16 07:19:50 +01:00
```sh
chown -R www-data:www-data /var/www/html
```
2022-09-07 13:03:51 +02:00
> chmod -R 775 /var/www/html/storage
2022-06-17 16:48:58 +02:00
> P.S. please give a star if you like it :wink: