Ceci est une ancienne révision du document !


PHP

PHP (acronyme récursif pour "PHP: Hypertext Preprocessor", PHP étant au départ l'acronyme de Personal Home Page) est un langage de programmation principalement utilisé pour produire des pages web de manière dynamique. Il est donc, dans la très grande majorité des cas, couplé à un serveur HTTP (comme Apache) pour la communication avec le client web.

La production de pages web dynamiques pouvant nécessiter une interaction avec une base de données, PHP est souvent utilisé en association avec un système de gestion de base de données (SGBD) comme MySQL.

Installation minimale

Pour installer PHP avec Apache et MySQL ou MariaDB, reportez-vous de préférence à la page LAMP.

Il existe 4 manières d'installer et utiliser PHP sur Ubuntu :

Pour un serveur web on utilisera principalement PHP soit en FastCGI, soit en module d'Apache.

Si on utilise Apache et pour un site à trafic ordinaire, on utilisera de préférence le module d'Apache parce qu'il est beaucoup plus simple à mettre en place et à administrer.

Pour un trafic à plusieurs milliers de visites par heure, mieux vaut utiliser PHP en FastCGI (parce qu'il est capable de traiter plusieurs processus simultanément).
Avec un serveur HTTP autre que Apache, on utilise aussi PHP en FastCGI : il n'existe pas de module PHP pour Nginx ou Lighttpd.

Chacun de ces paquets installera toutes les dépendances nécessaires au fonctionnement de PHP sur votre machine.

Sous Xenial (16.04), à moins qu'on ait déjà installé le module d'Apache, le paquet php installe par dépendance php-fpm (FastCGI).

Tandis que sous Debian le paquet php installe par défaut le module d'Apache, et Apache.

Attention donc à ne pas installer le paquet php sans le paquet libapache2-mod-php si vous ne souhaitez pas utiliser php-fpm.

Ce comportement a été corrigé sous Bionic (18.04), qui rejoint celui de Debian.

Installation des modules complémentaires

PHP est alors installée. Cependant la plupart des scripts PHP (CMS, forums, applications web en tout genre) utilisent des modules de PHP pour bénéficier de certaines fonctionnalités.

Voici comment installer rapidement les modules les plus courants :

sudo apt install php-curl php-gd php-intl php-json php-mbstring php-mcrypt php-xml php-zip

Pour plus de détails, voir la page dédiée aux modules PHP.

Association avec un serveur de base de données

PHP permet de se connecter à différents types de serveurs de base de données. Pour cela il est également nécessaire d'installer des modules complémentaires.

Il est important de souligner que l'installation d'un de ces modules PHP est indépendante de l'installation du serveur de base de données correspondant, ces serveurs n'étant pas nécessairement déployés localement.

La configuration de PHP se fait via un fichier php.ini.

Pour le module PHP d'Apache, le chemin d'accès au fichier php.ini sera généralement :

  • sous Trusty (Ubuntu 14.04) : /etc/php5/apache2/php.ini
  • sous Xenial (Ubuntu 16.04) : /etc/php/7.0/apache2/php.ini
  • sous Bionic (Ubuntu 18.04) : /etc/php/7.2/apache2/php.ini

Les fichiers de configuration ne sont pas les mêmes pour utiliser PHP en ligne de commande : /etc/php/7.0/cli/php.ini
ou en script FastCGI : /etc/php/7.0/fpm/php.ini

Ceci explique parfois des différences de comportement entre PHP exécuté par Apache, et manuellement en ligne de commande.

Activer le rapport d'erreur

Si vous développez une application en local, il est souvent utile de visualiser les messages d'erreurs directement sur votre page web. Ces erreurs sont cependant généralement aussi accessibles dans le journal d'erreur du serveur HTTP (/var/log/apache2/error.log pour Apache).

Pour afficher les erreurs, avec Apache vous pouvez par exemple définir des règles dans un fichier .htaccess à la racine de votre hôte virtuel :

.htaccess
php_flag display_errors on
php_value error_reporting "E_ALL"

error_reporting définit le niveau d'erreur que vous souhaitez afficher.

Le niveau d'erreur E_ALL affiche toutes les erreurs, y compris celles concernant des fonctionnalités dépréciées (qui seront désactivées dans des versions futures de PHP) ou des erreurs strictes, qu'on n'a pas forcément envie de corriger.
On peut désactiver l'affichage de ces messages pas toujours très importants en remplaçant cette ligne par celle-ci :

php_value error_reporting "E_ALL & ~E_NOTICE & ~E_STRICT"

Les directives display_errors et error_reporting sont aussi accessibles pour définir l'affichage des erreurs globalement, directement dans votre fichier php.ini.
Pour PHP 7.0 :

/etc/php/7.0/apache2/php.ini
...
display_errors=on
error_reporting=E_ALL & ~E_NOTICE & ~E_STRICT
...

Désactiver le rapport d'erreur

Pour un site en production, mieux vaut désactiver l'affichage des erreurs et se référer uniquement au log d'erreur du serveur HTTP :

.htaccess
php_flag display_errors off

Page blanche

Une page blanche inattendue affichée immédiatement indique très certainement que l'affichage des retours d'erreur sur la page n'est pas activé.

Vous pouvez activer le rapport d'erreur, ou consulter le log d'erreur de votre serveur HTTP pour en savoir plus sur le problème rencontré.

Erreur 403, 404, 500

Les erreurs de ce type ne sont a priori pas liées directement à PHP, mais au serveur HTTP. Si vous utilisez Apache consultez la documentation à ce sujet.

Attente puis erreur 503 "service indisponible"

Cette erreur indique que le serveur HTTP est dans les choux. Le service existe mais prend apparemment un temps interminable à répondre.

  • En premier lieu redémarrez le serveur HTTP (et PHP si vous l'utilisez en FastCGI).
  • Si le problème se pose toujours, cela peut par exemple être dû au fait qu'un script entre dans une boucle infinie. En plus de surcharger le processeur, ce problème ne génèrera pas de message d'erreur ce qui en fait malheureusement un problème particulièrement compliqué à débugger. Si votre CMS ou application web utilise un système de cache, vous pouvez essayer de le vider et de le désactiver. Puis essayer de désinstaller les plugins installés récemment, défaire les mortifications récentes ou restaurer une sauvegarde de votre application PHP.
  • php.1526472780.txt.gz
  • Dernière modification: Le 16/05/2018, 14:13
  • par krodelabestiole