PHP-FPM personnal configuration and pool templates on Debian linux distribution.
Note: I use this package for my own projects, it contains only the features I need.
Requirements | Configuration | Pools | Documentation | Contributing | License
- Debian linux distribution: ~10.0
- PHP-FPM: ~8.0
I do not modify any PHP configuration files. I just add new configuration files to override the default PHP configuration.
PHP includes a central configuration file /etc/php/8.x/fpm/php.ini
and, then, the particular configuration snippets (/etc/php/8.x/fpm/conf.d/*.ini
) which manage the modules.
PHP-FPM uses a central configuration file /etc/php/8.x/fpm/php-fpm.ini
and configures the pools using conf files located in /etc/php/8.x/fpm/pool.d/
Log directory is /var/log/php/
- zzz-prod: overrides the main PHP configuration for production server.
- zzz-dev: overrides the main PHP configuration for development server.
- Copy the configuration files into
/etc/php/8.x/mods-available/
- Edit the named like zzz-***.ini files and make changes as you need.
- Enable the configuration you need using
phpenmod zzz-***
- Review your settings using
php -i
I wrote thoses templates to ease the process of creating named-based PHP-FPM pools.
Each pool runs under is own user/group process (see adduser documentation). The process manager is set to ondemand
.
- fpm/phpdisconf.sh: bash script used to disable a pool configuration.
- fpm/phpenconf.sh: bash script used to enable a pool configuration.
- fpm/conf-available/10-php-fpm.conf: overrides the main PHP-FPM configuration (php-fpm.conf)
- fpm/conf-available/20-domain_01.tld.conf: pool settings for domain_01.tld.
- fpm/conf-available/20-domain_02.tld.conf: pool settings for domain_02.tld.
- fpm/conf-available/common.conf: contains common settings used by all pools.
- fpm/conf-available/www.conf: default PHP FPM pool settings.
Note: replace x by the minor version of PHP. Ex: php-fpm8.x --test becomes php-fpm8.0 --test
- Copy all the files and directories into /etc/php/8.x/fpm
- Move the default pool from
/etc/php/8.x/fpm/pool.d/www.conf
to/etc/php/8.x/fpm/conf-available/www.conf
- Make executable the
phpdisconf.sh
script file usingchmod u+x /etc/php/8.x/fpm/phpdisconf.sh
- Make executable the
phpenconf.sh
script file usingchmod u+x /etc/php/8.x/fpm/phpenconf.sh
- Edit the FPM configuration file (
/etc/php/8.x/fpm/conf-available/10-php-fpm.conf
) and make changes as you need. - Enable yours FPM settings using
./phpenconf.sh 10-php-fpm
- Edit the named like
/etc/php/8.x/fpm/conf-available/20-***.conf
files and make changes as you need. - Enable the pools using
./phpenconf.sh 20-domain_01.tld 20-domain_02.tld
- Test the validity of your php-fpm configuration syntax using
php-fpm8.0 --test
- Restart the PHP-FPM using
systemctl restart php8.x-fpm.service
I wrote and I use this package for my own projects. And, unfortunately, I do not provide exhaustive documentation. Please read the code and the comments ;)
For instructions on how to use, best practices, templates and other usage information, please visit the PHP documentation.
Thanks you for taking the time to contribute. Please fork the repository and make changes as you'd like.
As I use these configuration and templates for my own projects, it contains only the features I need. But If you have any ideas, just open an issue and tell me what you think. Pull requests are also warmly welcome.
If you encounter any bugs in the configuration or templates, please open an issue.
Be sure to include a title and clear description,as much relevant information as possible, and a code sample or an executable test case demonstrating the expected behavior that is not occurring.
php-fpm configuration and templates are open-source and are licensed under the MIT License.