Debian Stretch come server locale per uso casalingo va benissimo ma spesso ci si trova ad affrontare situazione dove si è obsoleti, questo mi è accaduto con php che in debian era fermo alla versione 5.6 mentre da bacports poteva arrivare alla 7.0, alcune web-app chiedevano un upgrade così mi spingo avanti e provo a passare a php7.3.
Nel corso dell’operazione che ho in ballo da alcuni mesi ho aggiunto un passaggio, ho portato apache2.4 dall’usare invece di mpm-prefork (vecchio default che non supportava più HTTP2) con php7.3, a una verione di mpm ( Multi-Processing Module ) diversa che già da Jessie viene usata come default in una nuova installazione di apache2, questa è mpm-event che abbinanto a php7.3-fpm sembra essere un ottima in coppia.
PHP7.3
Per passare a php7.3 occore affidarsi a sorgenti diverse da quelle ufficiali ma comunque sicure, grazie allo sviluppatore debian sury , carichiamo la chiave.
# wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg
aggiugiamo al nostro sources.list
deb https://packages.sury.org/php/ stretch main
Nel caso si voglia fare un pinning nel file /ect/apt/preferences mettiamo
Package: *
Pin: release a=stretch
Pin-Priority: 999
Package: *
Pin: release n=stretch-backports
Pin-Priority: 500
Package: *
Pin: release o=deb.sury.org
Pin-Priority: 500
Ora aggiorniamo e installiamo i nuovi pacchetti :
# aptitude update
# aptitude install php7.3 libapache2-mod-php7.3 php7.3-bz2 php7.3-cgi php7.3-cli php7.3-common php7.3-curl php7.3-fpm php7.3-gd php7.3-gmp php7.3-imap php7.3-intl php7.3-json php7.3-mbstring php7.3-mysql php7.3-opcache php7.3-pspell php7.3-readline
Prima di avviare il nuovo modulo andiamo ad applicare le modifiche necesarie al file /etc/php/7.3/apache2/php.ini , ovvero copiando quelle presenti nel vecchio file di configurazione, a questo punto dobbiamo caricare il modulo su apache2 e riavviare il servizio.
# a2dismod php7.0
# a2enmod php7.3
# systemctl restart apache2
In questo modo avremmo caricato il modulo di php7.3, nel caso di problemi con le nostre webapp è possibile tornare in pochi secondi all’uso di php7.0, disabilitando il 7.3 e caricando il 7.0 c
mpm-event & php7.3-fpm
Ora che abbiamo abilitato php7.3 potremmo essere soddisfatti ma vogliamo qualcosa di più e decidiamo di allinearci ai tempi e cambiare MPM ,di seguito un’ottima spiegazione su come lavorano i vari mpm ( Multi-Processing Module )
prefork
mpm_prefork
is.. well.. it’s compatible with everything.
It spins off a number of child processes for serving requests, and the
child processes only serve one request at a time. Because it’s got the
server process sitting there, ready for action, and not needing to deal
with thread marshaling, it’s actually faster than the more
modern threaded MPMs when you’re only dealing with a single request at a
time – but concurrent requests suffer, since they’re made to wait in
line until a server process is free. Additionally, attempting to scale
up in the count of prefork child processes, you’ll easily suck down some
serious RAM.
It’s probably not advisable to use prefork unless you need a module that’s not thread safe.
Use if: You need modules that break when threads are used, like mod_php
. Even then, consider using FastCGI and php-fpm
.
Don’t use if: Your modules won’t break in threading.
worker
mpm_worker
uses threading – which is a big help for
concurrency. Worker spins off some child processes, which in turn spin
off child threads; similar to prefork, some spare threads are kept ready
if possible, to service incoming connections. This approach is much
kinder on RAM, since the thread count doesn’t have a direct bearing on
memory use like the server count does in prefork. It also handles
concurrency much more easily, since the connections just need to wait
for a free thread (which is usually available) instead of a spare server
in prefork.
Use if: You’re on Apache 2.2, or 2.4 and you’re running primarily SSL.
Don’t use if: You really can’t go wrong, unless you need prefork for compatibility.
However, note that the treads are attached to connections and not requests – which means that a keep-alive connection always keeps a hold of a thread until it’s closed (which can be a long time, depending on your configuration). Which is why we have..
event
mpm_event
is very similar to worker, structurally; it’s
just been moved from ‘experimental’ to ‘stable’ status in Apache 2.4.
The big difference is that it uses a dedicated thread to deal with the
kept-alive connections, and hands requests down to child threads only
when a request has actually been made (allowing those threads to free
back up immediately after the request is completed). This is great for
concurrency of clients that aren’t necessarily all active at a time, but
make occasional requests, and when the clients might have a long
keep-alive timeout.
The exception here is with SSL connections; in that case, it behaves identically to worker (gluing a given connection to a given thread until the connection closes).
Use if: You’re on Apache 2.4 and like threads, but you don’t like having threads waiting for idle connections. Everyone likes threads!
Don’t use if: You’re not on Apache 2.4, or you need prefork for compatibility.
Prima di procedere al caricamento dei moduli occorre apportare le dovute modifiche al file /etc/apache2/sites-avaiable /mysite-ssl.conf inserendo queste opzioni :
# Run php-fpm via proxy_fcgi
# https://serverfault.com/questions/450628/apache-2-4-php-fpm-proxypassmatch#672969
<FilesMatch \.php$>
SetHandler "proxy:unix:/run/php/php7.3-fpm.sock|fcgi://localhost"
</FilesMatch>
<Proxy fcgi://localhost>
ProxySet connectiontimeout=5 timeout=240
</Proxy>
RewriteCond %{REQUEST_FILENAME} \.php$
RewriteCond %{DOCUMENT_ROOT}/%{REQUEST_URI} !-f
RewriteRule (.*) - [H=text/html]
<Directory "/www/html/">
Options FollowSymLinks
AllowOverride All
Require all granted
RewriteEngine On
A questo punto possiamo procedere al cambio dei module e riavviare l’indiano.
# a2dismod php7.3 mpm_prefork
# a2enmod proxy_fcgi setenvif mpm_event rewrite headers env dir mime ssl http2
# a2enconf php7.3-fpm
Un semplice test sul nostro server in una pagina phptest.php con all’interno :
<?php
// Visualizza tutte le informazioni, default: INFO_ALL
phpinfo();
?>
Il risultato dovrebbe essere come questo :
Nel caso si voglia disabilitare la navigazione tra le varie dir, basta aggiunger un file .htaccess con il seguente contenuto:
Options -Indexes
Accedendo alle opzioni svipuppatore del vostro browser con una console è possibile vedere anche che http2 è tornato a funzionare.
Testando le varie applicazioni installate posso confermare che il 95% delle applicazioni a continuato a funzionare correttamente, ha fallito l’upgrade groupoffice che volevo abbandonare da un po e non supporta mpm-event , mentre ha continuato a funzionare nextcloud 15.0.5 , una php photo gallery , rainloop webmail e mediawiki 1.32.0.
Ache da qui è possibile tornare sui propri passi andando a modificare i vari file.conf di cui avevate fatto una copia prima di fare le modifiche e operando al contrario i passaggi prima indicati sui moduli, così consiglio la prova a tutti coloro che hanno un’oretta da spendere.
In caso di problemi è sempre necessario osservare i log , e se volete provare a postare un commento posso vedere se ho dimenticato qualcosa dei miei appunti.
il sito configurato è questo?
Caro lablinux questo sito è ospitato sul server del dominio.
Solo il fatto di accedere con HTTP e non HTTPS ti fa capire che non c’è HTTP2.
La macchina in questione è il mio server casalingo che mi fa da relay mail server da più di 15 anni, e anche se per uso esclusivamente personale mi piace averlo a posto con tutto che funzioni.
Il passaggio a php7.3 è stato legato a motivi di sicurezza, mentre a mpm-event una scelta verso il futuro perché su una nuova installazione dovresti già trovarti in queste condizioni.
I miglioramenti sono tangibilissimi.
Will test this tomorrow on my test server with debian 9.8.0. Gracias.