Für Ubuntu 20-22-Benutzer:

Für Ubuntu 20-22-Benutzer:

ich installierteApache/2.4.54,PHP72-FPM,PHP74-FPMund einige andere Versionen von PHP-FPM auf Arch Linux. Anscheinend gibt es eine Fehlkonfiguration inhttpd.conf, PHP kann nichts interpretieren und der Browser kommentiert den Code aus.

Was ich versucht habe:

httpd.conf:

LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so

httpd-vhosts.conf:

<VirtualHost *:80>
    LoadModule php7_module modules/libphp72.so
    AddHandler php72-script php
    Include conf/extra/php72-module.conf
    ...

php72-module.conf:

<IfModule dir_module>
    <IfModule php_module7>
        <FilesMatch "\.php$">
            SetHandler application/x-httpd-php
            SetHandler "proxy:unix:/run/php72-fpm/php-fpm.sock|fcgi://localhost/"
            ...

php72-fpm is active.

Und

php -vkehrt zurück:PHP 8.1.12 (cli)


Aktualisiert:

Bin umgezogen:

<FilesMatch "\.php$">
    SetHandler "proxy:unix:/run/php72-fpm/php-fpm.sock|fcgi://localhost/"

zu <VirtualHost>und bekam [503 Unavailable],

Fehlerprotokoll:

[proxy:error] FCGI: attempt to connect to Unix domain socket /run/php-fpm72/php-fpm.sock (*:80) failed
[proxy_fcgi:error] failed to make connection to backend: httpd-UDS

Antwort1

Ich glaube, Sie mischen in Ihrer Konfiguration php-fpm mit modphp. Die einzigen Schritte, die Sie ausführen müssen, sind diese:

sudo a2dismod php7.x          # disable modphp (optional)
sudo a2dismod mpm_prefork     # to use php-fpm, you need to switch to mpm_event
sudo a2enmod mpm_event        # enable mpm_event
sudo a2enmod proxy proxy_fcgi # enable proxy_fcgi, required for php-fpm
sudo a2enconf php7.2-fpm      # enable php7.2-fpm

Es besteht keine Notwendigkeit, Ihre Vhosts-Datei zu aktualisieren, es sei denn, Archlinux wird nicht mit den Apache-Helfern geliefert a2*.

Update nach Ihrem Update

Stellen Sie sicher, dass Sie an diesem bestimmten Ort einen Unix-Socket haben. Sie sollten wahrscheinlich in Ihrer /etc/php/fpm/pool.d/xxx.confKonfiguration den genauen Standort Ihres Sockets überprüfen und dann php-fpm neu starten.

Antwort2

Für Ubuntu 20-22-Benutzer:

Zweck:

Installieren Sie fpm mit Sockets + FCGID-Modul + wenden Sie Benutzerrechte auf Anfragen pro Domäne an.

Schritt 1: Installation

sudo apt-get update
sudo systemctl stop apache2
sudo apt-get install libapache2-mod-fcgid
sudo apt-get install php8.1-fpm

# ubuntu 20 missing libs?!
sudo apt-get install php-mbstring
sudo apt-get install php-gd

Schritt 2: Module deaktivieren/aktivieren

sudo a2dismod php* mpm_prerfork cgi cgid
sudo a2enmod mpm_event fcgid proxy_fcgi headers rewrite
# Ubuntu 20
sudo a2enconf php7.4-fpm
# Ubuntu 22
sudo a2enconf php8.1-fpm

Schritt 3: Konfigurationsbefehle hinzufügen

Benutzer: "john"

Domäne: "mydomain.com"

(a). Apache FPM-Konfiguration

sudo nano /etc/apache2/mods-available/fcgid.conf

Typ:

<IfModule mod_fcgid.c>
  FcgidConnectTimeout 20
  AddType   application/x-httpd-php .php
  AddHandler    application/x-httpd-php .php
  <IfModule mod_mime.c>
    AddHandler fcgid-script .fcgi
  </IfModule>
</IfModule>

(b). FPM-Konfiguration

# Ubuntu 20
sudo cp /etc/php/7.4/fpm/pool.d/www.conf /etc/php/7.4/fpm/pool.d/mydomain.com.conf
# Ubuntu 22
sudo cp /etc/php/8.1/fpm/pool.d/www.conf /etc/php/8.1/fpm/pool.d/mydomain.com.conf

ändern:

[www] -> [mydomain.com]
user = www-data -> user = john
group = www-data -> group = john

hinzufügen oder leer lassen:

;;;;;;;;;;
; Memory ;
;;;;;;;;;;
php_admin_value[memory_limit] = 12M
php_admin_value[post_max_size] = 12M
php_admin_value[upload_max_filesize] = 12M
;;;;;;;;;;;;
; Settings ;
;;;;;;;;;;;;
php_value[user_ini.filename] = ".user.ini"
php_value[default_charset] = "UTF-8"
php_flag[short_open_tag] = Off
php_flag[display_errors] = On
php_flag[display_startup_errors] = On
php_flag[log_errors] = On
php_value[log_errors_max_len] = 1024
php_flag[report_memleaks] = On
php_flag[html_errors] = On
php_value[error_reporting] = E_ALL & ~E_DEPRECATED & ~E_STRICT
php_flag[file_uploads] = On
php_value[max_file_uploads] = 20
php_flag[allow_url_fopen] = On
php_flag[allow_url_include] = Off
php_value[session.save_handler] = files
php_flag[session.use_strict_mode] = 1
php_flag[session.use_cookies] = 1
php_flag[session.use_only_cookies] = 1
; temporary disabled fro STEP 5 system('whoami') to run!
;php_admin_value[disable_functions] = exec,passthru,shell_exec,system
;;;;;;;;;;;;;;;;;;;;;;;;;
; Paths and Directories ;
;;;;;;;;;;;;;;;;;;;;;;;;;
php_admin_value[error_log] = "/var/www/mydomain.com/log/php_errors.log"
php_admin_value[open_basedir] = "/var/www/mydomain.com/"
php_admin_value[doc_root] = "/var/www/mydomain.com"
php_admin_value[sys_temp_dir] = "/var/www/mydomain.com/tmp"
php_admin_value[upload_tmp_dir] = "/var/www/mydomain.com/tmp"
php_admin_value[session.save_path] = "/var/www/mydomain.com/session"
php_admin_value[soap.wsdl_cache_dir] = "/var/www/mydomain.com/tmp"
php_admin_value[curl.cainfo] = "/var/www/mydomain.com/server/registry/cacert.pem"

php_admin_value, php_admin_flag: kann vom Benutzer nicht geändert werden

php_value, php_flag: kann vom Benutzer geändert werden

(c). Erstellen Sie einen virtuellen Host

sudo nano /etc/apache2/sites-available/mydomain.com.conf

Typ:

<VirtualHost *:80>
ServerName mydomain.com.localhost
ServerAlias mydomain.com.localhost
ServerAdmin [email protected]

DocumentRoot /var/www/mydomain.com

Header set Access-Control-Allow-Origin "*"

<IfModule mod_fcgid.c>
    FcgidConnectTimeout 20
    AddType   application/x-httpd-php .php
    AddHandler    application/x-httpd-php .php

    # Ubuntu 20
    ProxyPassMatch " ^/(.*\.php(/.*)?)$" "unix:/run/php/php7.4-fpm.mydomain.com.sock|fcgi://localhost/var/www/mydomain.com/"
    # Ubuntu 22
    ProxyPassMatch " ^/(.*\.php(/.*)?)$" "unix:/run/php/php8.1-fpm.mydomain.com.sock|fcgi://localhost/var/www/mydomain.com/"

    <Directory /var/www/mydomain.com/>
        Options +ExecCGI
        Options -Indexes
        AllowOverride None
        Require all granted
#        FRONT CONTROLLER PATTERN
#        RewriteEngine On
#        RewriteCond "%{REQUEST_URI}" "!=/public_html/index.php"
#        RewriteRule "^(.*)$" "/public_html/index.php?$1" [NC,NE,L,PT,QSA]
    </Directory>
</IfModule>

# CPU usage limits 5s 10s
RLimitCPU 5 10
# memory limits to 10M 20M
RLimitMEM 10000000 20000000
# limit of forked processes 20 30
RLimitNPROC 20 30
LogLevel warn
ErrorLogFormat connection "[%t] New connection: [%{c}L] [ip: %a]"
ErrorLogFormat request "[%t] [%{c}L] New request: [%L] [pid %P] %F: %E"
ErrorLogFormat "[%t] [%{c}L] [%L] [%l] [pid %P] %F: %E: %M"
ErrorLog /var/www/mydomain.com/log/apache_error.log
CustomLog /var/www/mydomain.com/log/apache_access.log combined
ServerSignature Off
</VirtualHost>

(d). Netzwerk

sudo nano /etc/hosts

Typ(*):

127.0.0.1   localhost
127.0.0.1   mydomain.com
127.0.1.1   aspire1.machine.com aspire1

# The following lines are desirable for IPv6 capable hosts
::1     ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters

Datei erstellen oder bearbeiten:

sudo nano /etc/localhost

Geben Sie dort ein(*):

aspire1

(*) Ersetzen Sie es aspire1durch einen beliebigen Kurznamen.

Schritt 4: vhost laden

sudo a2ensite mydomain.conf

Schritt 5: Domänendateien + Berechtigungen erstellen

sudo mkdir -p  /var/www/mydomain.com/public_html
sudo mkdir /var/www/mydomain.com/log/
sudo touch /var/www/mydomain.com/public_html/info.php
sudo nano /var/www/mydomain.com/public_html/info.php

bei info.phpTyp:

<?php

echo '<b>';
echo php_sapi_name();
echo '</b><br>';

printf("%s<br>", 'DOCUMENT_ROOT=<b>'.$_SERVER['DOCUMENT_ROOT'].'</b>');

printf("%s", 'User=<b>');
system('whoami');
echo '</b><br>';

phpinfo();

Berechtigungen zuweisen:

sudo chown -R  john:john /var/www/mydomain.com
sudo find /var/www/mydomain.com -type d -name '*' -exec chmod 700 {} \;
sudo find /var/www/mydomain.com -type f -name '*' -exec chmod 600 {} \;
# open execute
sudo chmod 711 /var/www/mydomain.com
sudo chmod 711 /var/www/mydomain.com/public_html

Schritt 6: Zündung!

# Ubuntu 20
sudo service php7.4-fpm reload
sudo service php7.4-fpm restart
# Ubuntu 22
sudo service php8.1-fpm reload
sudo service php8.1-fpm restart
sudo systemctl restart apache2

Schritt 7: Cockpit!

Angenommen, Sie haben rewritedie Vhost-Datei nicht aktiviert, öffnen Sie den Browser und geben Sie ein:

mydomain.localhost/public_html/info.php

Schritt 8: Apache-Konfiguration wechseln

Wechseln wir von FPM zu modphp:

# Ubuntu 20
sudo a2disconf php7.4-fpm
sudo a2enmod php7.4
# Ubuntu 22
sudo a2disconf php8.1-fpm
sudo a2enmod php8.1
######
sudo a2dismod mpm_event
sudo a2dismod fcgid
sudo a2dismod proxy_fcgi
sudo a2enmod mpm_prefork
sudo systemctl restart apache2

Wechseln wir von modphp zu FPM:

# Ubuntu 20
sudo a2enconf php7.4-fpm
sudo a2dismod php7.4
# Ubuntu 22
sudo a2enconf php8.1-fpm
sudo a2dismod php8.1
######
sudo a2dismod mpm_prefork
sudo a2enmod mpm_event
sudo a2enmod fcgid
sudo a2enmod proxy_fcgi
# Ubuntu 20
sudo service php7.4-fpm reload
# Ubuntu 22
sudo service php8.1-fpm reload
######
sudo systemctl restart apache2

Viel Glück!

Art.-Nr.:

  1. https://www.linode.com/docs/guides/how-to-install-and-configure-fastcgi-and-php-fpm-on-ubuntu-18-04/
  2. https://www.linode.com/docs/guides/how-to-install-and-configure-fastcgi-and-php-fpm-on-debian-10/
  3. https://askubuntu.com/questions/1029564/php-7-2-fastcgi-doesnt-work-on-ubuntu-18-04-server/1458664#1458664

verwandte Informationen