bodsch.php

Ansible-Rolle: php

Ansible-Rolle zur Installation von fpm-php auf verschiedenen Systemen.

Nur inspiriert von geerlingguy

Erkennt die verfügbare PHP-Version basierend auf der Variable php_version.

Unterstützt die PHP-Versionen 7 und 8, sofern die entsprechenden Versionen verfügbar sind.

ArchLinux hat die PHP 7-Pakete aus ihrem Repository entfernt!

GitHub Workflow Status GitHub-Issues GitHub-Releases (neueste nach Datum) Ansible Downloads

Anforderungen & Abhängigkeiten

Ansible-Sammlungen

ansible-galaxy collection install bodsch.core

oder

ansible-galaxy collection install --requirements-file collections.yml

Betriebssysteme

Getestet auf

  • ArchLinux (nur PHP 8!)
  • Debian-basiert
    • Debian 12
    • Ubuntu 22.04

RedHat-basierte Systeme werden nicht mehr offiziell unterstützt! Es könnte funktionieren, muss aber nicht.

Nutzung

# Wählen Sie Ihre Version!
php_version: "8"

php_packages_state: present

php_fpm_log_directory: /var/log/php-fpm
php_fpm_tmp_upload_directory: /tmp/php-fpm
php_fpm_socket_directory: /run/php

php_fpm_log_level: notice

php_enable_php_fpm: true

php_fpm_listen: "127.0.0.1:9000"
php_fpm_listen_allowed_clients: "127.0.0.1"
php_fpm_pm:
  max_children: 50
  start_servers: 5
  spare_servers:
    min: 5
    max: 5

php_use_managed_ini: true

php_expose_php: "On"
php_memory_limit: "256M"
php_max_execution_time: "60"
php_max_input_time: "60"
php_max_input_vars: "1000"
php_realpath_cache_size: "32K"

php_file_uploads: "On"
php_upload_max_filesize: "64M"
php_max_file_uploads: "20"

php_post_max_size: "32M"
php_date_timezone: "Europe/Berlin"
php_allow_url_fopen: "On"

php_sendmail_path: "/usr/sbin/sendmail -t -i"
php_output_buffering: "4096"
php_short_open_tag: "Off"
php_disable_functions: []

php_session_cookie_lifetime: 0
php_session_gc_probability: 1
php_session_gc_divisor: 1000
php_session_gc_maxlifetime: 1440
php_session_save_handler: files
php_session_save_path: ''
php_session_cache_expire: 180

php_error_reporting: "E_ALL & ~E_DEPRECATED & ~E_STRICT"
php_display_errors: "Off"
php_display_startup_errors: "Off"

php_packages: []

php_fpm_default_pool:
  delete: false
  name: www.conf

php_fpm_pools: []

# PHP-Module
php_modules: []

Benutzerdefinierte Pakete

Um weitere PHP-Pakete zu installieren, können Sie diese in php_packages angeben.

Z.B.:

php_packages:
  - php-ldap

Für die Pakete ist keine Versionsangabe erforderlich, wie es beispielsweise für RedHat- und Remis-Pakete nötig wäre. Die Rolle sorgt dafür, dass der Paketname gültig ist.

Als Beispiel würde php-ldap zu php73-php-ldap.

PHP-Pools

php_fpm_pools:
  - name: worker-01
    user: "{{ php_fpm_pool_user }}"
    group: "{{ php_fpm_pool_group }}"
    listen.owner: "{{ php_fpm_pool_user }}"
    listen.group: "{{ php_fpm_pool_group }}"
    listen: "{{ php_fpm_socket_directory }}/$pool.sock"
    # statisch, dynamisch oder on-demand
    pm: ondemand
    pm.max_children: 10
    pm.start_servers: 4
    pm.min_spare_servers: 2
    pm.max_spare_servers: 6
    pm.status_path: /status

  - name: worker-02
    user: "{{ php_fpm_pool_user }}"
    group: "{{ php_fpm_pool_group }}"
    listen.owner: "{{ php_fpm_pool_user }}"
    listen.group: "{{ php_fpm_pool_group }}"
    listen: "{{ php_fpm_socket_directory }}/$pool.sock"
    pm: dynamic
    pm.max_children: 10
    pm.start_servers: 4
    pm.min_spare_servers: 2
    pm.max_spare_servers: 6
    pm.status_path: /status
    ping.path: /ping
    ping.response: pong
    access.log: "{{ php_fpm_log_directory }}/$pool_access.log"
    access.format: "%R - %n - %{HTTP_HOST}e - %u %t \"%m %r [%Q%q]\" %s %f %{mili}d %{kilo}M %C%%"
    chdir: /
    env:
      PATH: "/usr/local/bin:/usr/bin:/bin"
      TMPDIR: "{{ php_fpm_tmp_upload_directory }}"
    php_admin_value:
      date.timezone: "Europe/Berlin"
      log_errors: 'on'
      max_execution_time: 300
      memory_limit: 512M
      upload_max_filesize: 32M

PHP-Module

php_modules:
  # gd
  - name: gd
    enabled: true
    priority: 20
    content: |
      extension=gd
  # OpCache-Einstellungen
  - name: opcache
    enabled: true
    priority: 10
    content: |
      zend_extension=opcache
      opcache.enable=1
      opcache.enable_cli=1
      opcache.memory_consumption=128
      opcache.interned_strings_buffer=16
      opcache.max_accelerated_files=10000
      opcache.max_wasted_percentage=5
      opcache.validate_timestamps=1
      opcache.revalidate_path=0
      opcache.revalidate_freq=1
      opcache.max_file_size=0
  # PDO MySQL
  - name: pdo_mysql
    enabled: true
    priority: 20
    content: |
      extension=pdo_mysql

Unter Dokumentation finden Sie einige Modulkonfigurationen, die aus php.ini kopiert wurden.


Mitwirkung

Bitte lesen Sie Mitwirkung

Entwicklung, Zweige (Git-Tags)

Der master-Zweig ist mein Arbeitspferd, enthält die "neueste, heißeste Software" und kann völlig kaputt sein!

Wenn Sie etwas Stabiles verwenden möchten, nutzen Sie bitte eine getaggte Version!


Autor

  • Bodo Schulz

Lizenz

Apache

KOSTENLOSE SOFTWARE, HELL JAE!

Über das Projekt

ansible role to install and configure php-fpm

Installieren
ansible-galaxy install bodsch.php
GitHub Repository
Lizenz
apache-2.0
Downloads
2.2k
Besitzer
ex-developer (c, c++, php), ex-system administrator / engineer, keep-it-simple, monitoring, automation, system architect