


Que dois-je faire si nginx ne trouve pas le processus php ?
Solution pour laquelle nginx ne trouve pas le processus php : 1. Modifiez la configuration de nginx.conf 2. Utilisez try_files pour capturer les URL inexistantes et renvoyer une erreur.
L'environnement d'exploitation de cet article : système Windows7, version PHP7.1, ordinateur DELL G3
nginx Que dois-je faire si le processus php est introuvable ?
nginx ne trouve pas le fichier php
Utilisez php-fpm pour analyser PHP. "Aucun fichier d'entrée spécifié" et "Fichier introuvable" sont des erreurs courantes qui causent des problèmes aux nouveaux utilisateurs de nginx. ne trouve pas le fichier de configuration SCRIPT_FILENAME.php à exécuter, php-fpm renvoie l'invite d'erreur 404 par défaut à nginx.
Par exemple, mon site Web n'a pas test.php sous document_root Lorsque vous accédez à ce fichier, vous pouvez voir le contenu renvoyé en capturant le paquet.
HTTP/1.1 404 Not Found Date: Fri, 21 Dec 2012 08:15:28 GMT Content-Type: text/html Proxy-Connection: close Server: nginx/1.2.5 X-Powered-By: PHP/5.4.7 Via: 1.1 c3300 (NetCache NetApp/6.0.7) Content-Length: 16 File not found.
Beaucoup de gens ne veulent pas que les utilisateurs voient directement ce message d'erreur 404 par défaut et souhaitent personnaliser l'erreur 404
Avant de donner la solution, analysons d'abord comment éviter ce type d'erreur 404, puis dites la vérité Que faire face à cette situation (par exemple, l'utilisateur entre un mauvais chemin qui n'existe pas) afin qu'une page d'erreur 404 personnalisée puisse être affichée.
1. Le mauvais chemin est envoyé au processus php-fpm
Lorsque ce type d'erreur se produit, neuf cas sur dix sont causés par le processus back-end fastcgi qui reçoit le mauvais chemin (SCRIPT_FILENAME), et la raison principale La raison pour laquelle le fastcgi back-end reçoit le mauvais chemin est une erreur de configuration.
La configuration courante de nginx.conf est la suivante :
server { listen [::]:80; server_name example.com www.example.com; access_log /var/www/logs/example.com.access.log; location / { root /var/www/example.com; index index.html index.htm index.pl; } location /images { autoindex on; } location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /var/www/example.com$fastcgi_script_name; include fastcgi_params; } }
Il y a beaucoup de choses déraisonnables dans cette configuration L'un des problèmes évidents est que la directive racine est placée dans l'emplacement/bloc. Si la directive racine est définie dans un bloc d'emplacement, la directive racine ne peut prendre effet qu'à l'emplacement où elle se trouve. Il n'y a pas de directive racine dans d'autres emplacements. Par exemple, le bloc location /images ne correspondra à aucune requête. Vous devez configurer la directive racine à plusieurs reprises dans chaque requête pour résoudre ce problème. Par conséquent, nous devons placer la directive racine dans le bloc serveur, afin que chaque emplacement hérite de la racine du document définie par le bloc serveur parent. Si un emplacement doit définir une racine document_root différente, vous pouvez définir une directive racine distincte dans l'emplacement.
Un autre problème est que le paramètre fastCGI SCRIPT_FILENAME est codé en dur. Si vous modifiez la valeur de la directive racine ou déplacez le fichier vers un autre répertoire, php-fpm renverra l'erreur "Aucun fichier d'entrée spécifié" car SCRIPT_FILENAME est codé en dur dans la configuration et ne change pas avec le changement de $document_root. On peut le modifier. SCRIPT_FILENAME est configuré comme suit :
fastcgi_param SCRIPT_FILENAME documentrootfastcgi_script_name;
On ne peut donc pas oublier de configurer la directive root dans le bloc serveur, sinon la valeur de documentroot sera vide et seul fastcgi_script_name sera passé à php-fpm, ce qui provoquera l'erreur "Aucun fichier d'entrée spécifié".
2. Le fichier demandé n'existe vraiment pas
Lorsque nginx reçoit une demande pour un fichier .php qui n'est pas là, car nginx vérifiera uniquement si $uri se termine par .php et ne jugera pas si le fichier existe , les requêtes se terminant par .php nginx seront envoyées directement à php-fpm pour traitement. Si le fichier est introuvable lors du traitement php-fpm, il renverra "Aucun fichier d'entrée spécifié" avec un en-tête "404 Not Found".
Solution
Nous interceptons les fichiers inexistants dans nginx, demandons et renvoyons une erreur 404 personnalisée
Utilisez try_files pour capturer des URL inexistantes et renvoyer des erreurs.
location ~ .php$ { try_files $uri =404; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME .... ................................... ................................... }
La configuration ci-dessus vérifiera si le fichier .php existe. S'il n'existe pas, une page 404 sera renvoyée.
Apprentissage recommandé : "Tutoriel vidéo PHP"
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment confirmer si Nginx est démarré: 1. Utilisez la ligne de commande: SystemCTl Status Nginx (Linux / Unix), netStat -ano | Findstr 80 (Windows); 2. Vérifiez si le port 80 est ouvert; 3. Vérifiez le message de démarrage NGINX dans le journal système; 4. Utilisez des outils tiers, tels que Nagios, Zabbix et Icinga.

Comment configurer Nginx dans Windows? Installez Nginx et créez une configuration d'hôte virtuelle. Modifiez le fichier de configuration principale et incluez la configuration de l'hôte virtuel. Démarrer ou recharger nginx. Testez la configuration et affichez le site Web. Activer sélectivement SSL et configurer les certificats SSL. Définissez sélectivement le pare-feu pour permettre le trafic Port 80 et 443.

Dans Linux, utilisez la commande suivante pour vérifier si Nginx est démarré: SystemCTL Status Nginx Juges Basé sur la sortie de la commande: si "Active: Active (Running)" s'affiche, Nginx est démarré. Si "Active: Inactive (Dead)" est affiché, Nginx est arrêté.

Étapes pour démarrer Nginx dans Linux: Vérifiez si Nginx est installé. Utilisez SystemCTL Start Nginx pour démarrer le service NGINX. Utilisez SystemCTL Activer Nginx pour activer le démarrage automatique de Nginx au démarrage du système. Utilisez SystemCTL Status Nginx pour vérifier que le démarrage est réussi. Visitez http: // localhost dans un navigateur Web pour afficher la page de bienvenue par défaut.

Réponse à la question: 304 Erreur non modifiée indique que le navigateur a mis en cache la dernière version de ressource de la demande du client. Solution: 1. Effacer le cache du navigateur; 2. Désactiver le cache du navigateur; 3. Configurer Nginx pour permettre le cache client; 4. Vérifier les autorisations du fichier; 5. Vérifier le hachage du fichier; 6. Désactiver le CDN ou le cache proxy inversé; 7. Redémarrez Nginx.

Le serveur n'a pas l'autorisation d'accéder à la ressource demandée, ce qui donne une erreur NGINX 403. Les solutions incluent: vérifier les autorisations de fichiers. Vérifiez la configuration .htaccess. Vérifiez la configuration de Nginx. Configurez les autorisations Selinux. Vérifiez les règles du pare-feu. Dépanner d'autres causes telles que les problèmes de navigateur, les défaillances du serveur ou d'autres erreurs possibles.

Le démarrage d'un serveur Nginx nécessite différentes étapes en fonction des différents systèmes d'exploitation: Système Linux / Unix: Installez le package NGINX (par exemple, en utilisant Apt-Get ou Yum). Utilisez SystemCTL pour démarrer un service NGINX (par exemple, sudo systemctl start nginx). Système Windows: téléchargez et installez les fichiers binaires Windows. Démarrer Nginx à l'aide de l'exécutable Nginx.exe (par exemple, nginx.exe -c conf \ nginx.conf). Peu importe le système d'exploitation que vous utilisez, vous pouvez accéder au serveur IP

Comment corriger l'erreur interdite Nginx 403? Vérifier les autorisations de fichier ou de répertoire; 2. Vérifier le fichier .htaccess; 3. Vérifiez le fichier de configuration NGINX; 4. Redémarrer Nginx. D'autres causes possibles incluent les règles de pare-feu, les paramètres de Selinux ou les problèmes d'application.
