Files
nginx-php-fpm/README.md

184 lines
4.2 KiB
Markdown
Raw Normal View History

2023-01-04 18:04:25 +02:00
[![Build](https://github.com/jkaninda/nginx-php-fpm/actions/workflows/build.yml/badge.svg)](https://github.com/jkaninda/nginx-php-fpm/actions/workflows/build.yml)
2024-11-16 20:55:33 +01:00
[![Tests](https://github.com/jkaninda/nginx-php-fpm/actions/workflows/tests.yml/badge.svg)](https://github.com/jkaninda/nginx-php-fpm/actions/workflows/tests.yml)
2022-07-01 18:21:34 +02:00
![Docker Image Size (latest by date)](https://img.shields.io/docker/image-size/jkaninda/nginx-php-fpm?style=flat-square)
![Docker Pulls](https://img.shields.io/docker/pulls/jkaninda/nginx-php-fpm?style=flat-square)
# Nginx PHP-FPM Docker image
2022-09-01 18:13:56 +02:00
> 🐳 Full Docker image for Nginx PHP-FPM container created to run Laravel or any php based applications.
2022-07-01 18:21:34 +02:00
- [Docker Hub](https://hub.docker.com/r/jkaninda/nginx-php-fpm)
2022-09-21 10:16:31 +02:00
- [Github](https://github.com/jkaninda/nginx-php-fpm)
2022-07-01 18:21:34 +02:00
2023-12-16 07:26:54 +01:00
## PHP Versions:
2024-11-24 13:18:20 +01:00
- 8.4
2023-12-16 07:26:18 +01:00
- 8.3
- 8.2
- 8.1
- 8.0
- 7.4
- 7.2
2022-07-01 18:21:34 +02:00
## Specifications:
* Composer
* OpenSSL PHP Extension
* XML PHP Extension
* PDO PHP Extension
* Rdkafka PHP Extension
* Redis PHP Extension
* Mbstring PHP Extension
* PCNTL PHP Extension
* ZIP PHP Extension
* GD PHP Extension
* BCMath PHP Extension
* Memcached
* Laravel Cron Job
* Laravel Schedule
* Supervisord
2022-09-01 18:13:56 +02:00
* Nodejs
* NPM
2022-07-01 18:21:34 +02:00
## Simple docker-compose usage:
```yml
services:
2022-07-02 11:42:38 +02:00
app:
2024-06-08 08:33:56 +02:00
image: jkaninda/nginx-php-fpm:8.3
container_name: app
restart: unless-stopped
user: www-data # Optional - for production usage
2022-07-01 18:21:34 +02:00
volumes:
#Project root
- ./src:/var/www/html
2022-07-01 18:21:34 +02:00
ports:
- "80:80"
networks:
- default #if you're using networks between containers
```
## Docker:
### Run
2022-07-01 18:21:34 +02:00
```sh
docker compose up -d
```
### Create Laravel project
```sh
docker compose exec app composer create-project --prefer-dist laravel/laravel .
```
### Artisan generate key
```sh
docker compose exec app php artisan key:generate
```
### Storage link
```sh
docker compose exec app php artisan storage:link
```
### Fix permissions
```sh
docker compose exec app chmod -R 777 storage bootstrap/cache
```
### Laravel migration
```sh
docker compose exec app php artisan migrate
2022-07-01 18:21:34 +02:00
```
###
2022-07-01 18:21:34 +02:00
```sh
2022-08-14 14:43:00 +02:00
docker exec -it app bash
2022-07-01 18:21:34 +02:00
```
## Advanced Nignx-php-fpm:
### docker-compose.yml
```yml
version: '3'
services:
2022-07-02 11:42:38 +02:00
app:
2022-07-01 18:21:34 +02:00
image: jkaninda/nginx-php-fpm
container_name: app
2022-07-01 18:21:34 +02:00
restart: unless-stopped
ports:
- "80:80"
volumes:
#Project root
- ./:/var/www/html
- ~/.ssh:/root/.ssh # If you use private CVS
2022-08-14 14:43:00 +02:00
#./php.ini:/usr/local/etc/php/conf.d/php.ini # Optional, your custom php init file
2022-07-01 18:21:34 +02:00
environment:
- APP_ENV=development # Optional, or production
2022-08-14 14:43:00 +02:00
- LARAVEL_PROCS_NUMBER=2 # Optional, Laravel queue:work process number
#- CLIENT_MAX_BODY_SIZE=20M # Optional
#- DOMAIN=example.com # Optional
2022-09-21 10:16:31 +02:00
- DOCUMENT_ROOT=/var/www/html #Optional
2022-08-14 14:43:00 +02:00
2022-07-01 18:21:34 +02:00
```
2023-05-29 01:32:26 +02:00
Default web root:
```
/var/www/html
```
2022-07-01 18:21:34 +02:00
## Docker run
```sh
docker compose up -d
2022-07-01 18:21:34 +02:00
```
2023-01-04 18:04:25 +02:00
## Build from base
Dockerfile
```Dockerfile
2023-12-16 07:25:17 +01:00
FROM jkaninda/nginx-php-fpm:8.3
2023-01-04 18:04:25 +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:25:17 +01:00
# Custom cache invalidation / optional
#ARG CACHEBUST=1
# composer install / Optional
2023-12-16 07:25:17 +01:00
#RUN composer install
# Fix permissions
RUN chown -R www-data:www-data /var/www/html
USER www-data
2023-01-04 18:04:25 +02:00
```
2022-07-01 18:21:34 +02:00
## Nginx custom config:
2022-07-01 18:26:36 +02:00
### Enable custom nginx config files
2022-07-01 18:21:34 +02:00
> /var/www/html/conf/nginx/nginx.conf
2022-07-01 18:26:06 +02:00
2022-07-01 18:21:34 +02:00
> /var/www/html/conf/nginx/nginx-site.conf
2022-07-02 11:42:38 +02:00
## Supervisord
### Add more supervisor process in
2024-01-14 14:54:33 +01:00
> /etc/supervisor/conf.d/
2022-07-02 11:42:38 +02:00
2023-11-13 15:14:43 +01:00
In case you want to execute and maintain a task or process with supervisor.
2023-11-13 15:15:48 +01:00
2023-11-13 15:14:43 +01:00
Find below an example with Apache Kafka, when you want to maintain a consumer process.
### 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-09-21 10:16:31 +02:00
### Storage permision issue
2023-12-16 07:25:17 +01:00
```sh
docker compose exec php-fpm /bin/bash
2023-12-16 07:25:17 +01:00
```
```sh
chown -R www-data:www-data /var/www/html/
```
2022-09-21 10:23:03 +02:00
2022-09-21 10:16:31 +02:00
> chmod -R 775 /var/www/html/storage
2022-09-21 10:17:47 +02:00
2023-12-16 07:25:17 +01:00
> P.S. please give a star if you like it :wink: